js实现轮播图的完整代码


Posted in Javascript onOctober 26, 2020

今天写一个完整的轮播图,首先它需要实现三个功能:

1.鼠标放在小圆点上实现轮播

2.点击焦点按钮实现轮播

3.无缝自动轮播

轮播图的原理:

一系列的大小相等的图片平铺,利用CSS布局只显示一张图片,其余隐藏。通过计算偏移量(封装一个动画函数)自动播放,或通过手动点击事件切换图片。

js实现轮播图的完整代码

html布局:

<div id="box" class="all">
 <div class="inner"> <!-- 相框-->
 <ul>
 <li><a href="#"><img src="images/18.jpg" width="550" height="320" alt=""></a></li>
 <li><a href="#"><img src="images/19.jpg" width="550" height="320" alt=""></a></li>
 <li><a href="#"><img src="images/14.jpg" width="550" height="320" alt=""></a></li>
 <li><a href="#"><img src="images/17.jpg" width="550" height="320" alt=""></a></li>

 </ul>
 <ol> <!--里面存放小圆点-->

 </ol>
 </div>
 <div class="focusD" id="arr">
 <span id="left"><</span>
 <span id="right">></span>
 </div>
</div>

css样式:

* {
 margin: 0;
 padding: 0;
 }
 /*<--清除底部三像素距离-->*/
 img {
 vertical-align: top;
 }

 .all {
 width: 550px;
 height: 320px;
 margin: 100px auto;
 padding: 5px;
 border: 1px solid #ccc;
 position: relative;
 }

 .inner {
 position: relative;
 width: 550px;
 height: 320px;
 background-color: pink;
 overflow: hidden;
 }

 .inner ul {
 width: 1000%;
 list-style: none;
 position: absolute;
 top: 0;
 left: 0;
 }

 .inner ul li {
 float: left;
 }

 .focusD {
 position: absolute;
 left: 0;
 top: 50%;
 width: 550px;
 padding: 0 10px;
 height: 30px;
 box-sizing: border-box;
 display: none;
 }

 .inner ol {
 position: absolute;
 right: 30px;
 bottom: 10px;
 }

 .inner ol li {
 width: 15px;
 display: inline-block;
 height: 15px;
 margin: 0 3px;
 cursor: pointer;
 line-height: 15px;
 text-align: center;
 background-color: #fff;
 }
 /*当前的高亮的小圆点*/
 .inner ol .current {
 background-color: orange;
 color: #fff;
 }

 .focusD span {
 display: inline-block;
 width: 25px;
 font-size: 24px;
 height: 30px;
 color: #ccc;
 line-height: 30px;
 text-align: center;
 background: rgba(255, 255, 255, 0.3);
 cursor: pointer;
 }

 #left {
 float: left;
 }

 #right {
 float: right;
}

显示效果:

js实现轮播图的完整代码

js部分:

 接下来我们要写js 代码 ,首先我们先获取我们需要的所有元素 。注:my$("id")即document.getElementById,为了简便即建的方法。

var index=0;
 //获取最外面的div
 var box = my$("box");
 //获取相框
 var inner = box.children[0];
 //获取去相框的宽度
 var imgWidth = inner.offsetWidth;
 // 获取ul
 var ulObj = inner.children[0];
 //获取ul中所有的li
 var list = ulObj.children;
 //获取ol
 var olObj = inner.children[1];
 //获取焦点
 var arr = my$("arr");

然后我们需要给它创建小按钮即小圆点并注册鼠标进入事件,再此之前 我们要明白,小圆点 1 2 3 并不是写死的,它是根据ul li中的图片张数来决定的 ,所以 我们要先在js中给div中的ol中的添加li(即小圆点),并且给ul中的图片几li添加索引值以便下一步的操作。

//创建小按钮-----根据ul中li的个数
 for (var i = 0; i < list.length; i++) {
 var liObjs = document.createElement("li");
 olObj.appendChild(liObjs);
 liObjs.innerHTML = (i + 1);
 //在ol中每个li中增加自定义属性,添加索引值
 liObjs.setAttribute("index", i);
 //注册鼠标进入事件
 liObjs.onmouseover = function () {
 //先干掉所有背景颜色
 for (var j = 0; j < olObj.children.length; j++) {
 olObj.children[j].removeAttribute("class");
 }
 //设置当前鼠标进来的类样式
 this.className = "current";
 //获取ol中li的索引值
 index = this.getAttribute("index");
 //移动ul
 animate(ulObj, -index * imgWidth); //移动动画函数
 };
 }
 //设置第一个ol中li的背景颜色
 olObj.children[0].className = "current";

要实现无缝滚动 就需要多一张图片才行 ,即克隆第一张图片,放到最后面。

//克隆ol中第一个li放到最后一个
 ulObj.appendChild(ulObj.children[0].cloneNode(true));

下一步就要实现点击左右的按钮实现轮播

//点击右边按钮
 my$("right").onclick=clickHandle;
 function clickHandle() {
 if (index==ulObj.children.length-1){
 ulObj.style.left=0+"px";
 index=0;
 }
 index++;
 animate(ulObj,-index*imgWidth);
 if (index==list.length-1){
 olObj.children[0].className="current";
 olObj.children[olObj.children.length-1].className="";
 }else {
 for (var i=0;i<olObj.children.length;i++){
  olObj.children[i].className="";
 }
 olObj.children[index].className="current";
 }
 };
 //点击左边按钮
 my$("left").onclick=function () {
 if (index==0){
 index=list.length-1;
 ulObj.style.left=-index*imgWidth+"px";
 }
 index--;
 animate(ulObj,-index*imgWidth);
 for (var i=0;i<olObj.children.length;i++){
 olObj.children[i].className="";
 }
 olObj.children[index].className="current";
 };

最后一步就是自动轮播,即可以创建一个定时器,每隔一段时间就调用左右按钮的点击事件,相当于点按钮,但是要注意的是当鼠标放进相框的时候要清除定时器,不然在你点击的时候它还是会自动轮播。

完整js代码:

<script>
 var index=0;
 //获取最外面的div
 var box = my$("box");
 //获取相框
 var inner = box.children[0];
 //获取去相框的宽度
 var imgWidth = inner.offsetWidth;
 // 获取ul
 var ulObj = inner.children[0];
 //获取ul中所有的li
 var list = ulObj.children;
 //获取ol
 var olObj = inner.children[1];
 //获取焦点
 var arr = my$("arr");

 //创建小按钮-----根据ul中li的个数
 for (var i = 0; i < list.length; i++) {
 var liObjs = document.createElement("li");
 olObj.appendChild(liObjs);
 liObjs.innerHTML = (i + 1);
 //在ol中每个li中增加自定义属性,添加索引值
 liObjs.setAttribute("index", i);
 //注册鼠标进入事件
 liObjs.onmouseover = function () {
 //先干掉所有背景颜色
 for (var j = 0; j < olObj.children.length; j++) {
 olObj.children[j].removeAttribute("class");
 }
 //设置当前鼠标进来的类样式
 this.className = "current";
 //获取ol中li的索引值
 index = this.getAttribute("index");
 //移动ul
 animate(ulObj, -index * imgWidth); //移动动画函数
 };
 }
 //设置第一个ol中li的背景颜色
 olObj.children[0].className = "current";
 //克隆ol中第一个li放到最后一个
 ulObj.appendChild(ulObj.children[0].cloneNode(true));


 var timeId=setInterval(clickHandle,3000);

 my$("box").onmouseover=function(){
 arr.style.display="block";
 clearInterval(timeId);
 };
 //点击右边按钮
 my$("right").onclick=clickHandle;
 function clickHandle() {
 if (index==ulObj.children.length-1){
 ulObj.style.left=0+"px";
 index=0;
 }
 index++;
 animate(ulObj,-index*imgWidth);
 if (index==list.length-1){
 olObj.children[0].className="current";
 olObj.children[olObj.children.length-1].className="";
 }else {
 for (var i=0;i<olObj.children.length;i++){
  olObj.children[i].className="";
 }
 olObj.children[index].className="current";
 }
 };
 //点击左边按钮
 my$("left").onclick=function () {
 if (index==0){
 index=list.length-1;
 ulObj.style.left=-index*imgWidth+"px";
 }
 index--;
 animate(ulObj,-index*imgWidth);
 for (var i=0;i<olObj.children.length;i++){
 olObj.children[i].className="";
 }
 olObj.children[index].className="current";
 };

 my$("box").onmouseout=function(){
 arr.style.display="none";
 timeId=setInterval(clickHandle,3000);
 };



 // 设置一个元素,移动到指定位置
 function animate(element, target) {
 clearInterval(element.timeId);
 element.timeId = setInterval(function () {
 var current = element.offsetLeft;
 var step = 9;
 step = current > target ? -step : step;
 current += step;
 if (Math.abs(target - current) > Math.abs(step)) {
 element.style.left = current + "px";
 } else {
 clearInterval(element.timeId);
 element.style.left = target + "px";
 }
 }, 10);
 }
function my$(id) {
 
 return document.getElementById(id);


}
</script>

精彩专题分享:jQuery图片轮播 JavaScript图片轮播 Bootstrap图片轮播

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js通过八个点 拖动改变div大小的实现方法
Mar 05 Javascript
js 针对html DOM元素操作等经验累积
Mar 11 Javascript
javascript截取字符串小结
Apr 28 Javascript
avalon js实现仿微博拖动图片排序
Aug 14 Javascript
JavaScript小技巧整理
Dec 30 Javascript
在页面中输出当前客户端时间javascript实例代码
Mar 02 Javascript
详解axios在vue中的简单配置与使用
May 10 Javascript
微信小程序开发之toast等弹框提示使用教程
Jun 08 Javascript
jQuery查找和过滤_动力节点节点Java学院整理
Jul 04 jQuery
template.js前端模板引擎使用详解
Oct 10 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
Oct 18 Javascript
angularJs利用$scope处理升降序的方法
Oct 08 Javascript
JQuery扩展对象方法操作示例
Aug 21 #jQuery
详解Vue结合后台的列表增删改案例
Aug 21 #Javascript
JavaScript事件发布/订阅模式原理与用法分析
Aug 21 #Javascript
javascript和php使用ajax通信传递JSON的实例
Aug 21 #Javascript
小程序开发基础之view视图容器
Aug 21 #Javascript
详解微信小程序的 request 封装示例
Aug 21 #Javascript
Mint-UI时间组件起始时间问题及时间插件使用
Aug 20 #Javascript
You might like
风格模板初级不完全修改教程
2006/10/09 PHP
对比分析php中Cookie与Session的异同
2016/02/19 PHP
php根据地址获取百度地图经纬度的实例方法
2019/09/03 PHP
laravel中的fillable和guarded属性详解
2019/10/23 PHP
JS验证控制输入中英文字节长度(input、textarea等)具体实例
2013/06/21 Javascript
javascript代码运行不出来执行错误的可能情况整理
2013/10/18 Javascript
JQuery each()嵌套使用小结
2014/04/18 Javascript
node.js中的url.parse方法使用说明
2014/12/10 Javascript
Angularjs在初始化未完毕时出现闪烁问题的解决方法分析
2016/08/05 Javascript
JavaScript DOM节点操作方法总结
2016/08/23 Javascript
jQuery EasyUI封装简化操作
2016/09/18 Javascript
jQuery事件详解
2017/02/23 Javascript
javaScript 逻辑运算符使用技巧整理
2017/05/03 Javascript
Vue.js进行查询操作的实例详解
2017/08/25 Javascript
浅谈js基础数据类型和引用类型,深浅拷贝问题,以及内存分配问题
2017/09/02 Javascript
angular中不同的组件间传值与通信的方法
2017/11/04 Javascript
详解react-native WebView 返回处理(非回调方法可解决)
2018/02/27 Javascript
Node.js对MongoDB进行增删改查操作的实例代码
2019/04/18 Javascript
JavaScript函数式编程(Functional Programming)箭头函数(Arrow functions)用法分析
2019/05/22 Javascript
Python中实现参数类型检查的简单方法
2015/04/21 Python
简单介绍Python的Django框架加载模版的方式
2015/07/20 Python
Python使用装饰器进行django开发实例代码
2018/02/06 Python
python实现接口并发测试脚本
2019/06/25 Python
详解Python设计模式之策略模式
2020/06/15 Python
Python 开发工具通过 agent 代理使用的方法
2020/09/27 Python
使用phonegap进行提示操作的具体方法
2017/03/30 HTML / CSS
英国人最爱的饰品网站:Accessorize
2016/08/22 全球购物
英国和爱尔兰的自炊式豪华度假小屋:Rural Retreats
2018/06/08 全球购物
办公设备采购方案
2014/03/16 职场文书
国旗下的演讲稿
2014/05/08 职场文书
医学专业自荐信
2014/06/14 职场文书
学习雷锋月活动总结
2014/07/03 职场文书
交通事故委托书范本
2014/09/28 职场文书
2016特色励志班级口号
2015/12/24 职场文书
SpringBoot整合MongoDB的实现步骤
2021/06/23 MongoDB
简单总结SpringMVC拦截器的使用方法
2021/06/28 Java/Android