原生JS实现的自动轮播图功能详解


Posted in Javascript onDecember 28, 2018

本文实例讲述了原生JS实现的自动轮播图功能。分享给大家供大家参考,具体如下:

轮播图的用处

轮播图是现在网站网页上最常见的效果之一,很多网站上都会用到,淘宝京东等等。有些自动选项卡也是需要用到的,而且它的可重复性高。在这里分享一下,用js原生代码,实现轮播图的常见效果!

轮播图的原理

一系列的大小相等的图片平铺,利用CSS布局只显示一张图片,其余隐藏。通过定时器实现自动播放。

 原生JS实现的自动轮播图功能详解

Html布局

首先父容器banner存放所有内容,子容器img-list存放图片。子容器list存放按钮小圆点。圆点我使用了背景图片的方式!

<div id="banner">
  <ul id="img-list">
    <li><img src="images/banner1.png" alt="1"/></li>
    <li><img src="images/banner2.jpg" alt="2"/></li>
    <li><img src="images/banner3.png" alt="3"/></li>
  </ul>
  <div id="list">
    <span index="1" class="on"></span>
    <span index="2"></span>
    <span index="3"></span>
  </div>
</div>

css修饰

1、对盒子模型,文档流的理解,绝对定位问题。

2、图片有固定的的宽高,先在img-list中设置三张图片总共的宽,多余的将overflow: hidden;进行隐藏!载将其图片下的li设置往右浮动。

3、将list span中的宽高固定,给个背景图片。第一张图片上设个默认的黄色圆点图片。

#banner {
  width:100%;
  padding:0;
  clear: both;
  position: relative;
  height: 400px;
  z-index:1;
}
#img-list {
  display: block;
  width:5760px;
  height: 400px;
  overflow: hidden;
  z-index:1;
  position: relative;
}
#img-list li{
  float: left;
  width:100%;
  height: 400px;
  overflow: hidden;
  /* position: absolute;
  top:0;
  left:0; */
  z-index: 2;
}
#list {
  width:100%;
  height:18px;
  text-align: center;
  position: absolute;
  bottom: 10px;
  z-index: 100;
}
#list > span {
  width:18px;
  height: 18px;
  overflow: hidden;
  display: inline-block;
  margin:0 2px;
  background: url(../images/yuan.png);
  cursor: pointer;
}
#list .on {
  background: url(../images/huanyu.png);
}

JS效果

1、首先我们先设置自动播放的函数

2、然后鼠标滑过容器时停止播放,鼠标离开整个容器时继续播放至下一张。

3、再定义并调用自动播放函数

var banner=document.getElementById('banner');
var imglist=document.getElementById('img-list').getElementsByTagName("li");
var list=document.getElementById('list').getElementsByTagName('span');
var index=0;
var timer=null;
//设置自动播放函数
function autoPlay () {
   if (++index >= imglist.length) {index = 0};
   changeImg(index);
}
// 鼠标划过整个容器时停止自动播放
banner.onmouseover = function () {
   clearInterval(timer);
}
// 鼠标离开整个容器时继续播放至下一张
banner.onmouseout=function(){
   timer=setInterval(autoPlay,2000);
}
// 定义并调用自动播放函数
timer = setInterval(autoPlay, 2000);
接着定义图片的切换函数
// 定义图片切换函数
function changeImg (curIndex) {
   for (var i = 0; i < imglist.length; i++) {
     imglist[i].style.display = "none";
     list[i].className = "";
   }
   imglist[curIndex].style.display = "block";
   list[curIndex].className = "on";
}

最后遍历所有数字导航实现划过切换至对应的图片,需获得它的索引值

for (var i = 0; i < list.length; i++) {
 list[i].index=i;
 list[i].onmouseover = function () {
 clearInterval(timer);
 changeImg(this.index);
};

到此为止,我们的轮播所有代码完成!

还不算完美,继续努力!

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JS判断是否为数字,是否为整数,是否为浮点数的代码
Apr 24 Javascript
bgsound 背景音乐 的一些常用方法及特殊用法小结
May 11 Javascript
最新的10款jQuery内容滑块插件分享
Sep 18 Javascript
移除AngularJS下URL中的#字符的方法
Jun 19 Javascript
Javascript基础_简单比较undefined和null 值
Jun 14 Javascript
老生常谈JavaScript 正则表达式语法
Aug 20 Javascript
ES6中的数组扩展方法
Aug 26 Javascript
react-native ListView下拉刷新上拉加载实现代码
Aug 03 Javascript
微信小程序实现指定显示行数多余文字去掉用省略号代替
Jul 25 Javascript
优雅的elementUI table单元格可编辑实现方法详解
Dec 23 Javascript
前端插件之Bootstrap Dual Listbox使用教程
Jul 23 Javascript
JS Generator 函数的含义与用法实例总结
Apr 08 Javascript
jQuery实现的自定义轮播图功能详解
Dec 28 #jQuery
微信小程序实现简单跑马灯效果
May 26 #Javascript
详解如何快速配置webpack多入口脚手架
Dec 28 #Javascript
详解puppeteer使用代理
Dec 27 #Javascript
Angular(5.2-&gt;6.1)升级小结
Dec 27 #Javascript
详解angular2 控制视图的封装模式
Dec 27 #Javascript
JavaScript原型对象原理与应用分析
Dec 27 #Javascript
You might like
linux命令之调试工具strace的深入分析
2013/06/03 PHP
php实现的美国50个州选择列表实例
2015/04/20 PHP
DEFER怎么用?
2006/07/01 Javascript
在IE上直接编辑网页内容的js代码(IE地址栏js)
2009/04/27 Javascript
基于jQuery的淡入淡出可自动切换的幻灯插件打包下载
2010/09/15 Javascript
利用浏览器全屏api实现js全屏
2014/01/16 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
2015/08/21 Javascript
js淡入淡出焦点图幻灯片效果代码分享
2015/09/08 Javascript
探讨AngularJs中ui.route的简单应用
2016/11/16 Javascript
详解VUE 定义全局变量的几种实现方式
2017/06/01 Javascript
微信小程序自定义toast的实现代码
2018/11/16 Javascript
说说如何在Vue.js中实现数字输入组件的方法
2019/01/08 Javascript
结合axios对项目中的api请求进行封装操作
2020/09/21 Javascript
python 中文字符串的处理实现代码
2009/10/25 Python
Windows平台Python连接sqlite3数据库的方法分析
2017/07/12 Python
python assert的用处示例详解
2019/04/01 Python
Python Django给admin添加Action的方法实例详解
2019/04/29 Python
使用python serial 获取所有的串口名称的实例
2019/07/02 Python
用python生成与调用cntk模型代码演示方法
2019/08/26 Python
利用 Flask 动态展示 Pyecharts 图表数据方法小结
2019/09/04 Python
python软件都是免费的吗
2020/06/18 Python
Selenium之模拟登录铁路12306的示例代码
2020/07/31 Python
详解移动端h5页面根据屏幕适配的四种方案
2020/04/15 HTML / CSS
英国拳击装备购物网站:RDX Sports
2018/01/23 全球购物
Farfetch美国:奢侈品牌时尚购物平台
2019/05/02 全球购物
老师自我鉴定范文
2013/12/25 职场文书
书法培训心得体会
2014/01/05 职场文书
党员公开承诺书范文
2014/03/25 职场文书
团代会主持词
2014/04/02 职场文书
2014年内勤工作总结
2014/11/24 职场文书
2015年试用期工作总结范文
2015/05/28 职场文书
《普罗米修斯》教学反思
2016/02/22 职场文书
使用react-virtualized实现图片动态高度长列表的问题
2021/05/28 Javascript
微信小程序基础教程之echart的使用
2021/06/01 Javascript
Python爬虫入门案例之爬取二手房源数据
2021/10/16 Python
彻底解决MySQL使用中文乱码的方法
2022/01/22 MySQL