原生JS实现图片轮播切换效果
发布时间 - 2026-01-10 21:50:01 点击率:次首先来分析一下轮播图效果的实现原理:

1、父元素作为显示窗口,大小固定超出部分隐藏,即设置overflow:hidden;
2、子元素存放图片列表用ul,ul固定定位,参照为父元素,即父元素position:relative;ul元素position:absolute;
3、一个li即一张图片的宽度为父元素的显示宽度
4、初始时,ul的left为0,这时第一张图片即第一个li显示
5、点击下一张按钮,将整个ul左移,使第二个li对齐父元素的左边框,此时ul的left为负的一个li的宽度
6、点击上一张按钮,将整个ul右移
7、对特殊情况进行处理,即第一张图时点上一张,最后一张图时点下一张
第一张图时点上一张,我们滚动到最后一张图,整个ul左移,即把left值改为负的n-1张图的宽度;
最后一张图时点下一张,我们滚到第一张图的位置,整个ul右移,即把left值改为0
用一张图来帮助理解:
修改ul元素的left值很简单ul.style.left=设定值,就可以了,但我们想有一个滑动的效果,那我们需要用setInterval来实现
最后的效果如下:
动图不能录制太大CSDN有2M的限制_(:зゝ∠)_
下面放代码
script部分
<script>
window.onload= function () {
var nav=document.getElementById("nav").getElementsByTagName("li");
var img=document.getElementById("imgList");
var prev=document.getElementById("prev");
var next=document.getElementById("next");
var index=0;//当前图片序列号
var timer;//定时器名字
var iSpeed=-10;//滚动的速度
function goRoll(){
timer=setInterval(function () {
img.style.left=img.offsetLeft+iSpeed+'px';
var stop=-index*870+'px';//当达到目标位置是停止定时器
if(img.style.left==stop){
iSpeed=-10;
clearInterval(timer);
}
},10)
}
// 上一张和下一张点击效果
prev.onclick= function () {
if(index==0){
index=2;
iSpeed=-20;
}else{
index--;
iSpeed=10;
}
goRoll();
//img.style.left=-index*870+'px';
};
next.onclick= function () {
if(index==2){
index=0;
iSpeed=20;
}else{
index++;
iSpeed=-10;
}
goRoll();
//img.style.left=-index*870+'px';
};
}
</script>
html放一下
<div class="panel center-panel bc_rice">
<div class="panel-box">
<a class="prev-btn" id="prev"></a>
<div class="img-box">
<div class="list-box">
<ul class="img-list" id="imgList">
<li>
<img src="img/c1.jpg"/>
</li>
<li>
<img src="img/c2.jpg"/>
</li>
<li>
<img src="img/c3.jpg"/>
</li>
</ul>
</div>
</div>
<a class="next-btn" id="next"></a>
<img class="mT20" src="img/shadow1.png"/>
</div>
<div class="center-line bc_brown"></div>
</div>
CSS放一下
.fb{font-weight:bold;}
.c_fff{color:#fff;}
.f24{font-size:24px;}
.f72{font-size:72px;}
.lh40{line-height:40px;}
.bc_brown{background:#533d3b;}
.bc_green{background:#74cdab;}
.bc_rice{background:#ecf1c8;}
.bc_beige{background:#d1d5b0;}
.mT10{margin-top:10px;}
.mT20{margin-top:20px;}
.mT30{margin-top:30px;}
.mT40{margin-top:40px;}
.tc{text-align:center;}
.dblock{display:block;}
.clearfix:after{content:'';display:block;visibility:hidden;clear:both;line-height:0;font-size:0;}
.clearfix{zoom:1;}
html,body{width:100%;height:100%;font-size:14px;font-family:Myriad Pro;color:#433c3c;}
div,p,a,span,ul,li,em{margin:0;padding:0;}
ul li{list-style-type:none;}
a:hover{cursor:pointer;}
/*main-panel*/
.main-panel{width:100%;min-width:1030px;margin:0 auto;}
.main-panel .panel{width:100%;}
.main-panel .panel .line{width:100%;height:23px;background:url('../img/line.png');}
.main-panel .panel .panel-box{width:960px;height:100%;margin:0 auto;overflow:hidden;position:relative;}
.center-panel{height:510px;position:relative;}
.center-panel .panel-box{width:990px;z-index:1000;}
.center-panel .center-line{height:76px;position:absolute;width:100%;top:200px;z-index:10;}
.center-panel .panel-box a{width:51px;height:82px;display:block;position:absolute;top:200px;}
.center-panel .prev-btn{background:url('../img/Button-left.png');left:0;}
.center-panel .next-btn{background:url('../img/Button-right.png');right:0;}
.center-panel .img-box{width:940px;height:366px;background:url('../img/shadow.png');margin-top:45px;margin-left:10px;overflow:hidden;}
.center-panel .list-box{width:870px;height:334px;margin:16px auto;overflow:hidden;position:relative;}
.center-panel .img-list{width:4000px;height:334px;position:absolute;left:0;}
.center-panel .img-list li{width:870px;height:100%;float:left;}
因为我写了一整个页面都放出来没啥用,所以我只截取了用到的部分。
现在还是有些问题的,比如如果点击过快是会出问题的,这个以后看看能不能完善。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js图片轮播
# js图片轮播切换
# js轮播切换
# js实现支持手机滑动切换的轮播图片效果实例
# js图片轮播手动切换效果
# vue.js+elementUI实现点击左右箭头切换头像功能(类似轮播图效果)
# 原生js实现图片层叠轮播切换效果
# javascript实现图片自动和可控的轮播切换特效
# Bootstrap 最常用的JS插件系列总结(图片轮播、标签切换等)
# JS仿京东移动端手指拨动切换轮播图效果
# js实现淡入淡出轮播切换功能
# javascript五图轮播切换实用版
# js实现图片轮播切换效果
# 一张图
# 下一张
# 为父
# 即把
# 第一个
# 我只
# 太大
# 第二个
# 很简单
# 写了
# 过快
# 来实现
# 第一张
# 到第
# 没啥
# 需要用
# 大家多多
# 就可以
# 有一个
# 因为我
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251811 】
【
AI营销90571 】
相关推荐:
如何注册花生壳免费域名并搭建个人网站?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
JS实现鼠标移上去显示图片或微信二维码
C++时间戳转换成日期时间的步骤和示例代码
Win11怎样安装网易有道词典_Win11安装词典教程【步骤】
Laravel如何实现用户注册和登录?(Auth脚手架指南)
如何在云主机快速搭建网站站点?
魔方云NAT建站如何实现端口转发?
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧
如何为不同团队 ID 动态生成多个非值班状态按钮
如何为不同团队 ID 动态生成多个独立按钮
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
JS中对数组元素进行增删改移的方法总结
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
高防服务器租用指南:配置选择与快速部署攻略
如何基于云服务器快速搭建网站及云盘系统?
如何在不使用负向后查找的情况下匹配特定条件前的换行符
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作
Laravel如何处理表单验证?(Requests代码示例)
如何在IIS7上新建站点并设置安全权限?
如何快速生成凡客建站的专业级图册?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
免费网站制作appp,免费制作app哪个平台好?
Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?
中山网站制作网页,中山新生登记系统登记流程?
详解阿里云nginx服务器多站点的配置
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
Laravel Fortify是什么,和Jetstream有什么关系
php 三元运算符实例详细介绍
WEB开发之注册页面验证码倒计时代码的实现
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
简历在线制作网站免费版,如何创建个人简历?
如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
如何用搬瓦工VPS快速搭建个人网站?
如何有效防御Web建站篡改攻击?
音乐网站服务器如何优化API响应速度?
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
Laravel中的withCount方法怎么高效统计关联模型数量

