使用 HTML/JavaScript 实现滑动切换效果的图片轮播

使用 html/javascript 实现滑动切换效果的图片轮播

本文将指导你如何使用 HTML、CSS 和 JavaScript 为图片轮播添加滑动切换效果。我们将通过动态添加和移除 CSS 类来实现图片的滑入和滑出动画,从而增强用户体验,使轮播图的切换更加流畅自然。本文提供了详细的代码示例和步骤,帮助你轻松实现这一效果。

实现原理

核心思想是利用 CSS 的 animation 属性定义滑入 (slide-in) 和滑出 (slide-out) 动画,然后通过 JavaScript 在切换图片时动态地添加和移除这些 CSS 类。

步骤详解

HTML 结构:

首先,确保你的 HTML 结构包含一个容器,用于包裹轮播图的图片。每个图片都应该放在一个 div 元素中,例如 mySlides。

立即学习“Java免费学习笔记(深入)”;

1 / 6
@@##@@
Image 1 Description
2 / 6
@@##@@
Image 2 Description

CSS 样式:

定义 slide-in 和 slide-out 动画。确保你的 CSS 文件包含以下内容:

.slide-in {    -webkit-animation-name: slide-in-right;    -webkit-animation-duration: 1.5s;    animation-name: slide-in-right;    animation-duration: 1.5s;}.slide-out {    -webkit-animation-name: slide-out-left;    -webkit-animation-duration: 1.5s;    animation-name: slide-out-left;    animation-duration: 1.5s;}@keyframes slide-in-right {    from {        transform: translateX(100%);    }    to {        transform: translateX(0%);    }}@keyframes slide-out-left {    from {        transform: translateX(0%);    }    to {        transform: translateX(-100%);    }}

slide-in 动画:图片从右侧滑入。slide-out 动画:图片向左侧滑出。@keyframes 定义了动画的具体过程。

JavaScript 代码:

修改 JavaScript 代码,在显示新图片和隐藏旧图片时,动态添加和移除 CSS 类。

function showSlides(n) {    var i;    var slides = document.getElementsByClassName("mySlides");    if (n > slides.length) {        slideIndex = 1    }    if (n < 1) {        slideIndex = slides.length    }    // 找到当前显示的 slide 和即将显示的 slide    let slideToHide = document.querySelector(".mySlides[style='display: block;']");    let slideToShow = slides[slideIndex - 1];    // 移除所有 slides 的显示样式    for (i = 0; i < slides.length; i++) {        slides[i].style.display = "none";    }    // 添加动画类    if (slideToHide) {        slideToHide.classList.remove("slide-in");        slideToHide.classList.add("slide-out");    }    slideToShow.classList.remove("slide-out");    slideToShow.classList.add("slide-in");    // 显示 slide    slideToShow.style.display = "block";}

首先,获取当前显示的 slide (slideToHide) 和即将显示的 slide (slideToShow)。然后,移除 slideToHide 的 slide-in 类并添加 slide-out 类,使其滑出。接着,移除 slideToShow 的 slide-out 类并添加 slide-in 类,使其滑入。最后,设置 slideToShow 的 display 属性为 “block”,使其可见。

完整示例

* {    box-sizing: border-box}body {    font-family: nunito sans;    margin: 0}.mySlides {    display: none;}center > img {    vertical-align: middle;    height: 75vh;    width: auto !important;}.slideshow-container {    max-width: 1250px;    position: relative;    margin: auto;}/* Next & previous buttons */.prev,.next {    cursor: pointer;    position: absolute;    top: 50%;    width: auto;    padding: 16px;    margin-top: -22px;    color: white;    font-weight: bold;    font-size: 18px;    transition: 0.6s ease;    border-radius: 0 3px 3px 0;    user-select: none;}/* Position the "next button" to the right */.next {    right: 0;    border-radius: 3px 0 0 3px;}/* On hover, add a black background color with a little bit see-through */.prev:hover,.next:hover {    background-color: rgba(0, 0, 0, 0.8);}/* Caption text */.text {    color: #FFFFFF;    font-size: 22px;    position: absolute;    margin: 5px 0px;    width: 100%;    text-align: center;}/* Number text (1/3 etc) */.numbertext {    color: #ffffff;    font-size: 12px;    padding: 8px 12px;    position: absolute;    top: 0;}/* Fading animation */.slide-in {    -webkit-animation-name: slide-in-right;    -webkit-animation-duration: 1.5s;    animation-name: slide-in-right;    animation-duration: 1.5s;}.slide-out {    -webkit-animation-name: slide-out-left;    -webkit-animation-duration: 1.5s;    animation-name: slide-out-left;    animation-duration: 1.5s;}@keyframes slide-in-right {    from {        transform: translateX(100%);    }    to {        transform: translateX(0%);    }}@keyframes slide-out-left {    from {        transform: translateX(0%);    }    to {        transform: translateX(-100%);    }}/* On smaller screens, decrease text size */@media only screen and (max-width: 300px) {    .prev,    .next,    .text {        font-size: 11px    }}
1 / 6
@@##@@
HR Koopman postcard of 112th and Michigan, facing north, in 1896.
2 / 6
@@##@@
HR Koopman photograph of workmen digging sewer system on 111th and Michigan in 1900.
3 / 6
@@##@@
111th and Michigan in 1903 taken by HR Koopman.
4 / 6
@@##@@
HR Koopman postcard showing a busy section of South Michigan Avenue on 113th street in 1904.
5 / 6
@@##@@
Roseland celebrates its 60th anniversary with a huge parade on July 5th, 1909.
6 / 6
@@##@@
HR Koopman photograph of 115th and Michigan in 1910 showing horse and buggies, a streetcar, and bicycles.

var slideIndex = 0; showSlides(); function showSlides() { var i; var slides = document.getElementsByClassName("mySlides"); for (i = 0; i slides.length) {slideIndex = 1} // 找到当前显示的 slide 和即将显示的 slide let slideToHide = document.querySelector(".mySlides[style='display: block;']"); let slideToShow = slides[slideIndex - 1]; // 添加动画类 if (slideToHide) { slideToHide.classList.remove("slide-in"); slideToHide.classList.add("slide-out"); } slideToShow.classList.remove("slide-out"); slideToShow.classList.add("slide-in"); slides[slideIndex-1].style.display = "block"; setTimeout(showSlides, 2000); // Change image every 2 seconds }

注意事项

动画时长: 根据你的喜好调整 animation-duration 属性的值。动画效果: 可以尝试不同的 animation-timing-function 属性值,例如 ease-in-out,来改变动画的缓动效果。兼容性: 对于一些老旧的浏览器,可能需要添加 CSS 前缀,例如 -webkit-。性能: 复杂的动画可能会影响性能,特别是移动设备上。尽量保持动画简洁高效。

总结

通过本文的教程,你已经学会了如何使用 HTML、CSS 和 JavaScript 为图片轮播添加滑动切换效果。这种方法简单易懂,可以有效地提升用户体验。希望你能将这些知识应用到你的项目中,创造出更具吸引力的网页。

使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播使用 HTML/JavaScript 实现滑动切换效果的图片轮播

以上就是使用 HTML/JavaScript 实现滑动切换效果的图片轮播的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1583568.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 00:08:32
下一篇 2025年12月23日 00:08:45

相关推荐

  • JavaScript中遍历DOM集合并基于子元素内容动态操作父元素

    本文详细介绍了如何使用JavaScript高效遍历DOM集合,特别是处理`HTMLCollection`或`NodeList`,并通过访问每个父元素中的特定子元素内容来执行条件性操作。教程将重点讲解`document.querySelectorAll()`、`NodeList.forEach()`、…

    2025年12月23日
    000
  • 掌握CSS动画触发:解决元素可见性改变时动画不播放的问题

    本文探讨了当元素初始隐藏时,css动画无法按预期播放的常见问题。核心原因在于动画在页面加载时即已执行完毕。教程提供了一种通过javascript动态添加css类来触发动画的解决方案,确保动画在元素可见时才开始播放,并讨论了动画重复播放的处理方法。 理解问题:为什么CSS动画不按预期播放? 在前端开发…

    2025年12月23日
    000
  • JavaScript动态设置背景:避免background简写属性覆盖问题

    本文探讨了在javascript中动态设置html元素背景时,`background`简写属性可能导致背景图片和背景颜色相互覆盖的问题。通过深入分析`background`属性的行为,文章提供了一种解决方案:使用`background-image`和`background-color`等具体属性进行…

    2025年12月23日
    000
  • 如何实现移动端网站头部永久固定

    本教程将详细介绍如何通过CSS将移动端网站头部元素永久固定在屏幕顶部,解决`position: sticky`无法实现完全固定效果的问题。我们将对比`position: sticky`与`position: fixed`的差异,并提供简单易懂的CSS代码示例,确保您的移动端用户无论如何滚动,都能始终…

    2025年12月23日
    000
  • CSS实现单选框文本右侧多行显示

    本文介绍了如何使用CSS灵活地将单选框的文本标签显示在其右侧,并且允许文本内容多行显示。通过利用Flexbox布局,可以轻松实现单选框和标签的对齐,并控制它们之间的间距,使得界面更加美观和易于阅读。 在网页设计中,经常需要将单选框(radio button)与一段描述性的文本标签关联起来。默认情况下…

    2025年12月23日
    000
  • 优化无障碍:确保屏幕阅读器正确播报单选按钮状态

    本文旨在解决屏幕阅读器在自定义单选按钮组件中误报状态的问题。当包含 `tabindex` 属性的父级 `div` 元素抢占焦点时,屏幕阅读器可能无法正确识别实际 `input` 元素的选中状态。通过移除父级 `div` 上的 `tabindex` 属性,我们可以确保焦点直接落在原生 `input` …

    2025年12月23日
    000
  • CSS实现移动端头部导航永久固定:position: fixed 深度解析

    本文旨在解决移动端网站头部导航部分粘滞(滚动时隐藏,回滚时显示)的问题,并指导如何通过css实现头部导航的永久固定。我们将探讨`position: fixed`属性在实现这一功能上的有效性,并与`position: sticky`进行对比,提供清晰的实现步骤和注意事项,确保用户在任何滚动状态下都能看…

    2025年12月23日
    000
  • HTML数据如何用于用户画像 HTML数据用户行为分析的应用

    HTML通过嵌入脚本监听用户交互,实现点击、滚动、表单等行为数据采集;结合页面结构分析,可构建兴趣标签、行为路径及活跃度画像,应用于个性化推荐、A/B测试、流失预警和精准广告投放。 HTML数据本身是网页的结构化标记语言,单独来看并不直接包含用户行为信息。但当结合前端交互逻辑、日志采集和后端处理时,…

    2025年12月23日
    000
  • 使用 Selenium 和 Python 抓取点击按钮后网页的 HTML 代码

    本文旨在指导初学者使用 Selenium 和 Python 抓取网页中点击按钮后更新的 HTML 代码。通过示例代码演示如何定位按钮并模拟点击,以及如何获取每次点击后的完整页面源代码。我们将重点介绍如何通过文本定位元素,并处理页面跳转的情况,确保能够完整抓取每次点击后的页面数据。 使用 Seleni…

    2025年12月23日
    000
  • JavaScript条件渲染:当计数为零时隐藏Span元素

    本教程详细介绍了如何使用纯javascript高效地实现动态计数,并根据计数结果有条件地隐藏html “元素。我们将学习如何利用`document.queryselectorall`统计页面元素数量,并通过`hidden`属性在计数为零时自动隐藏对应的显示区域,同时强调使用`const`…

    2025年12月23日
    000
  • Android应用中集成网页内容的高效策略

    在Android应用中展示网页内容是常见的需求,它允许开发者复用现有网站内容或从后端动态获取数据。然而,实现这一目标有多种策略,选择合适的方法对于应用的性能、用户体验和维护性至关重要。本文将深入探讨两种主要方法:基于API的结构化数据渲染和使用`WebView`嵌入网页,并提供相应的实现指导和最佳实…

    2025年12月23日
    000
  • JavaScript Regex:修复HTML中标签的闭合问题

    本教程详细介绍了如何使用JavaScript正则表达式,识别并修复HTML代码中缺少自闭合斜杠的“的标签,并演示如何通过替换操作为其添加正确的闭合格式,从而标准化HTML结构。 背景与挑战 在处理html字符串时,有时会遇到一些标签格式不规范的情况,例如:在捕获组的内容之后,添加一个空格和正确的自…

    2025年12月23日 好文分享
    000
  • CSS动画触发机制与动态控制指南

    本文深入探讨了css动画在元素可见性改变时可能无法按预期触发的问题。核心在于css动画在元素加载时即开始执行,而非等待其可见性变化。教程提供了一种通过javascript动态添加/移除css类来精确控制动画触发时机的方法,并附带详细代码示例和实现可重复动画的注意事项,旨在帮助开发者实现更灵活、可控的…

    2025年12月23日
    000
  • CSS样式优先级:父元素能否直接覆盖子元素样式?

    在css中,父元素的样式通常无法直接覆盖子元素自身明确定义的样式。这主要归因于css的继承机制和优先级规则。子元素会优先应用自身定义的样式,除非该属性未被定义或显式设置为`inherit`。要修改子元素的特定样式,通常需要使用更具体的选择器直接作用于子元素,而非依赖父元素的样式传递。 理解CSS样式…

    2025年12月23日
    000
  • Vue.js开发服务器文件变更不自动编译刷新问题解析与优化

    本文旨在解决vue.js开发服务器在源文件修改后不自动编译刷新的常见问题。核心原因通常在于`vue.config.js`中`devserver`配置项对热模块替换(hmr)或实时重载的错误设置。通过移除或修正`hot: false`等配置,并理解vue cli默认行为,可以恢复预期的开发体验,实现代…

    2025年12月23日
    000
  • JavaScript多视频播放控制教程:实现单视频独播与暂停

    本教程详细介绍了如何使用JavaScript实现网页中多个视频元素的播放与暂停控制,尤其侧重于确保在任何时刻只有一个视频处于播放状态的“单视频独播”体验。文章将从基础的视频控制出发,逐步讲解如何通过遍历DOM元素和事件监听机制,实现多个视频的协同管理,并提供示例代码及最佳实践建议。 在现代网页设计中…

    2025年12月23日
    000
  • JavaScript条件隐藏计数器:当值为0时隐藏元素

    本教程将指导您如何使用纯javascript动态管理网页上的计数器显示。我们将学习如何获取特定元素的数量,并将该数量显示在指定的“元素中。更重要的是,当计数为零时,我们将实现一种机制来自动隐藏相应的“元素,从而优化用户界面,避免显示不必要的零值,并融入现代javascript…

    2025年12月23日
    000
  • Slick Carousel:动态提取图片Alt属性生成独立标题教程

    本教程详细介绍了如何在slick carousel中实现动态图片标题功能。通过监听slick的`init`和`afterchange`事件,文章演示了如何从当前显示图片的`alt`属性中提取文本,并将其作为独立的标题显示在指定区域,同时更新轮播的当前/总数指示器。内容涵盖html结构、javascr…

    2025年12月23日 好文分享
    000
  • 使元素宽度占据整个页面:CSS布局技巧与解决方案

    本文旨在解决如何使HTML元素(例如导航栏)宽度占据整个页面的问题。通过分析常见的CSS布局问题,本文将提供一种简单有效的解决方案,利用`flex`属性确保元素能够完全覆盖其父容器的宽度,从而实现期望的页面布局效果。同时,本文也将探讨一些可能导致宽度无法铺满的常见原因,并提供相应的排查思路。 在网页…

    2025年12月23日
    000
  • 掌握@media screen与Flexbox:构建现代响应式导航

    本文旨在深入探讨如何利用CSS的`@media screen`媒体查询和Flexbox布局技术,构建适应不同屏幕尺寸的响应式导航。文章首先指出在传统`float`布局中常见的媒体查询使用错误,随后详细介绍如何通过Flexbox实现更灵活、更易维护的响应式导航结构,并讨论了`float`与Flexbo…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信