首页 游戏 软件 资讯 排行榜 专题
首页
前端开发
HTML5轮播图全代码

HTML5轮播图全代码

热心网友
82
转载
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。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

MySQL视图如何处理自增主键映射_逻辑主键生成策略
数据库
MySQL视图如何处理自增主键映射_逻辑主键生成策略

MySQL视图自增主键映射与逻辑主键生成方案详解 在数据库设计与优化实践中,视图(View)是简化复杂查询、封装业务逻辑的强大工具。然而,许多开发者在操作视图时,常希望实现类似数据表的自动主键生成功能,这在实际应用中却面临诸多限制。本文将深入解析MySQL视图与自增主键的关系,并提供切实可行的逻辑主

热心网友
04.28
mysql数据库字符集如何统一调整_修改配置文件解决乱码问题
数据库
mysql数据库字符集如何统一调整_修改配置文件解决乱码问题

MySQL启动时默认字符集没生效?检查my cnf的加载顺序和位置 先明确一个关键点:MySQL启动时,并不会漫无目的地去读取所有可能的配置文件。它有一套固定的、按优先级排列的查找路径(通常是 etc my cnf、 etc mysql my cnf,最后才是 ~ my cnf),并且找到第一个

热心网友
04.28
如何建立基本医疗保险统筹基金和个人帐户
办公文书
如何建立基本医疗保险统筹基金和个人帐户

基本医疗保险的“双账户”模式:统筹与个人如何分工? 说起咱们的基本医疗保险,它的运作核心可以概括为“社会统筹与个人账户相结合”。简单来说,整个医保基金就像一个大池子,但这个池子被清晰地划分为两个部分:一个是大家共用的“统筹基金”,另一个则是属于参保人自己的“个人账户”。 那么,钱是怎么分别流入这两个

热心网友
04.28
如何定义记录类型_TYPE IS RECORD自定义多字段结构
数据库
如何定义记录类型_TYPE IS RECORD自定义多字段结构

TYPE IS RECORD 语法详解与核心应用指南 在PL SQL数据库编程中,TYPE IS RECORD是定义自定义复合数据类型的关键工具。其标准语法结构为:TYPE 类型名 IS RECORD (字段名 数据类型 [DEFAULT 默认值] [NOT NULL]);。通过该语法,开发者可以灵

热心网友
04.28
参保人可选择几家定点医疗机构
办公文书
参保人可选择几家定点医疗机构

在定点医疗机构的选择上,政策其实给参保人留出了不小的灵活空间。获得定点资格的专科和中医医疗机构,会自动成为统筹区内所有参保人的可选范围,这为大家获取特色医疗服务提供了基础保障。 在此之外,每位参保人还能根据自身需要,再额外挑选3到5家不同层次的医疗机构。比如,你可以选择一家综合三甲医院应对复杂病情,

热心网友
04.28