原生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 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】  北京的网站制作公司有哪些,哪个视频网站最好?  Swift开发中switch语句值绑定模式  如何在阿里云完成域名注册与建站?  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  如何在云主机快速搭建网站站点?  如何续费美橙建站之星域名及服务?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  教学论文网站制作软件有哪些,写论文用什么软件 ?  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  html5的keygen标签为什么废弃_替代方案说明【解答】  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  网站制作壁纸教程视频,电脑壁纸网站?  Java垃圾回收器的方法和原理总结  在线制作视频的网站有哪些,电脑如何制作视频短片?  Laravel如何使用Livewire构建动态组件?(入门代码)  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  简单实现jsp分页  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何正确选择百度移动适配建站域名?  php结合redis实现高并发下的抢购、秒杀功能的实例  java中使用zxing批量生成二维码立牌  如何在阿里云购买域名并搭建网站?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  php打包exe后无法访问网络共享_共享权限设置方法【教程】  UC浏览器如何设置启动页 UC浏览器启动页设置方法  潮流网站制作头像软件下载,适合母子的网名有哪些?  IOS倒计时设置UIButton标题title的抖动问题  如何在阿里云香港服务器快速搭建网站?  如何在IIS中新建站点并配置端口与IP地址?  如何在阿里云ECS服务器部署织梦CMS网站?  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  Android中AutoCompleteTextView自动提示  如何在万网自助建站中设置域名及备案?  Python文件操作最佳实践_稳定性说明【指导】  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  详解vue.js组件化开发实践  详解jQuery中基本的动画方法  Laravel如何集成Inertia.js与Vue/React?(安装配置)