当前位置: 首页
前端开发
HTML5轮播图全代码

HTML5轮播图全代码

热心网友 时间:2026-04-28
转载

轮播图原理深度解析与实战实现

轮播图的原理并不复杂,咱们可以把它想象成一场永不停止的传送带表演。假设有三张图片需要进行轮播,核心操作就是将这三张图片并排摆好,然后让这个整体向左匀速移动。关键在于,每当一张图片完全从显示窗口移出时,就立刻把它“瞬移”到队伍的最后端。如此循环,就形成了图片向一个方向无限滚动的视觉效果。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

为了实现平滑且人性化的轮播体验,通常需要两个定时器来协同工作。第一个定时器(暂且叫它定时器A)控制着图片整体移动的速度,让画面“流”起来。而第二个定时器(定时器B)则负责节奏,它会在每张图片完全进入显示窗口后,让轮播暂停片刻,给用户留出看清内容的时间,体验上会友好很多。

为了更直观地演示,下面我们用三个不同颜色的

方块来模拟图片进行操作。

构建基础HTML与CSS结构

首先,在HTML的body部分创建一个作为显示窗口的父容器div,并在其内部放置三个子div,分别代表三张“图片”。

接着,在头部添加CSS样式进行初步定义:

完成这一步后,页面会呈现一个黑色边框的显示框,内部红、绿、蓝三个方块默认会从上到下排列。

第一步:让“图片”并排显示

想让这三个方块并排且能自由移动,使用CSS定位是最直接的选择。考虑到需要精确控制每个方块的位置并使其相对父容器移动,相对定位(relative)和绝对定位(absolute)的组合就派上了用场。我们为显示框(#box)和所有图片块(.slide)添加position属性:

#box{
    width:100px;
    height:100px;
    border:1px solid black;
    position:relative;
}
.slide{
    width:100px;
    height:100px;
    position:absolute;
}

接下来,通过Ja vaScript在页面加载完成后初始化三个方块的位置。 这部分JS代码可以放在CSS样式之后,保持结构清晰。

 

当页面加载完毕,你会发现三个彩色的方块已经整齐地横向排列在一起了。

第二步:实现向左滚动动画

接下来就是让这排方块动起来,这里需要用到前面提到的定时器A。在onload函数的同级作用域下,添加如下代码:

function LeftMove(){
    var arr = document.getElementsByClassName("slide");//获取三个子div
    for(var i=0;i

此时,三个方块已经开始缓慢地向左滚动了。 但现在的滚动是连续不断的,我们需要引入第二个定时器B来制造“滚动-暂停-滚动”的节奏感。思路是让定时器B每隔一段时间(比如3秒)才启动一次定时器A,并且在每张“图片”完全移出时,主动暂停定时器A(即停止移动),等待定时器B的下一次召唤。

因此,我们需要在LeftMove函数的if判断中添加一句代码,用于在方块移出时清除当前移动定时器:

if(left<=-width){
    left=(arr.length-1)*width;//当图片完全走出显示框,拼接到末尾
    clearInterval(moveId);//关键:停止当前的移动
}

然后,创建定时器B及其控制函数:

function divInterval(){
    moveId=setInterval(LeftMove,10);//重新启动一个移动定时器
}
timeId=setInterval(divInterval,3000);//设置一个间隔3秒的“节奏”定时器

第三步:完善细节与体验优化

基础功能有了,但还需要一些打磨。首先,记得在CSS中为显示框(#box)加上overflow: hidden;,把移出框外的部分隐藏起来,这样轮播图才像样。

#box{
    width:100px;
    height:100px;
    border:1px solid black;
    position:relative;
    overflow:hidden; /* 隐藏溢出部分 */
}

增强交互体验是必须的。通常,当用户鼠标悬停在轮播图上时,应该暂停轮播;移开后再继续。这只需要在box元素上添加鼠标事件即可。修改box的开始标签:

并补充对应的JS函数:

function stop(){
    clearInterval(timeId);//鼠标悬停时,关闭控制节奏的定时器B
}
function start(){
    clearInterval(timeId);//重启前,先清除可能存在的旧定时器
    timeId=setInterval(divInterval,2000);//重新开启定时器B
}

还有一个容易被忽略但会影响体验的场景:浏览器页面切换。当用户切到其他标签页一段时间再回来,轮播图可能会出现“快进”动画。这是因为页面切出后,定时器仍在后台执行,但页面渲染被暂停了,等用户切回来时,浏览器会快速执行堆积的动画指令。解决方法是利用页面的焦点事件:

//页面失去焦点(如切换标签页)时停止定时器
onblur = function(){
    stop();
}
//页面重新获得焦点时启动定时器
onfocus = function(){
    start();
}

完整代码一览

将上述所有代码整合起来,就得到了一个功能完备的基础轮播图实现:




    
    轮播图
    
    


    

来源:https://www.jb51.net/html5/772647.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
禁止HTML页面滚动的操作方法

禁止HTML页面滚动的操作方法

在前端开发中,禁止HTML页面滚动通常涉及到对CSS样式或Ja vaScript的使用。以下是一些常见的方法: 1 使用CSS的overflow属性 最直接的思路,是通过设置HTML或body元素的 overflow 属性为 hidden 来禁止滚动。这么一来,任何超出视口的内容都会被隐藏,滚动的

时间:2026-04-28 17:41
uni-app怎么做类似于淘宝的物流时间轴 uni-app步骤条组件定制实现【实战】

uni-app怎么做类似于淘宝的物流时间轴 uni-app步骤条组件定制实现【实战】

uni-app 里用 u-steps 实现物流时间轴,为什么总对不上实际节点? 问题根源很明确:你把一个设计用于「线性流程」的步骤条,硬生生套在了「异步事件流」的物流场景上。这就像试图用整齐划一的阅兵方阵,去展示一场状况百出的越野赛跑。 淘宝的物流时间轴,本质上是一系列独立事件的集合。每个节点都有自

时间:2026-04-28 17:41
如何用 JavaScript 实现用户输入五个姓名并按顺序显示在网页上

如何用 JavaScript 实现用户输入五个姓名并按顺序显示在网页上

如何用 prompt() 收集五个姓名并动态渲染到页面?一份实战指南 在前端入门的实践环节里,有一个“经典关卡”:如何从用户那里收集一组数据,存起来,再漂亮地展示出来?听起来基础,但很多新手在第一关就卡住了——变量作用域混乱、DOM元素找不到、代码逻辑“断层”,这些都是常见问题。 今天,我们就以“收

时间:2026-04-28 17:41
关于html选择框创建占位符的问题

关于html选择框创建占位符的问题

为HTML选择框(Select)添加“占位符”的几种思路 在表单设计中,为文本输入框设置一个灰色的提示占位符(placeholder)早已是标准操作,用户体验非常好。但轮到下拉选择框(Select)时,不少开发者会发现事情没那么简单——HTML原生并没有提供类似的placeholder属性。 最直观

时间:2026-04-28 17:40
uni-app怎么隐藏导航栏 uni-app自定义顶部导航栏配置【详解】

uni-app怎么隐藏导航栏 uni-app自定义顶部导航栏配置【详解】

uni-app导航栏隐藏的真相:一份跨端开发的避坑指南 先直接说结论,这也是很多人试错过后的经验:na vigationBarHidden: true 确实是写法最简单、跨端最稳妥的隐藏方式,但它的生效范围仅限于小程序和H5。想在APP端真正移除原生导航栏?那必须祭出组合拳:na vigationS

时间:2026-04-28 17:40
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程