本文实例为大家分享了js实现自动播放匀速轮播图的具体代码,供大家参考,具体内容如下
函数封装: ( 匀速运动函数)
function animate(obj,target,step,speed){ clearInterval(obj.timer); var absStep = Math.abs(step); step = target > obj.offsetLeft ? absStep : -absStep; obj.timer = setInterval(function(){ var distance = Math.abs(target - obj.offsetLeft); obj.style.left = obj.offsetLeft + step + 'px'; if(distance < absStep){ clearInterval(obj.timer); obj.style.left = target + 'px'; } },speed); }
对象可以动态生成属性,用对象的timer,避免了全局变量的使用,
实现步骤:
1.动态生成ol导航条,并将导航条放入all中使其成为孩子节点
2.根据ul中图片数量动态生成li标签,使li成为ol的子节点,
3.给第0个li标签加上颜色(添加属性current)
4.用设置的属性的值去操作图片使图片移动,达到鼠标放上去移动到该图片效果,排它原理实现样式效果
5.深度克隆ul中的第一张图片并将图片放在ul的末尾
6.加入自动播放函数使其自动播放,设置两个变量key,squre,key的值用来计算图片的序号,squre用来计算当前li的序号
7.自动播放函数中排他原理设置当前li标签样式
8.在设置onmouseover和onmouseout事件鼠标放在盒子上暂停,鼠标离开盒子,继续运动
9.在鼠标放在li标签时让key等于当前图片的index属性值 ,并把key的值赋给squre。
实现细节:
1.动态给ul克隆出第0张图片补到末尾,以实现自动轮播是无缝的效果,
2.克隆分深克隆和浅克隆,深克隆克隆带标签内的所有内容,
3.浅克隆只克隆外部标签,深克隆参数为true
效果:
代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>匀速轮播动画</title> <style type="text/css"> *{ padding:0; margin:0; list-style:none; border:0;} .all{ width:500px; height:200px; padding:7px; border:1px solid #ccc; margin:100px auto; position:relative; } .screen{ width:500px; height:200px; overflow:hidden; position:relative; } .screen li{ width:500px; height:200px; overflow:hidden; float:left; } .screen ul{ position:absolute; left:0; top:0px; width:3000px; } .all ol{ position:absolute; right:10px; bottom:10px; line-height:20px; text-align:center; } .all ol li{ float:left; width:20px; height:20px; background:#fff; border:1px solid #ccc; margin-left:10px; cursor:pointer; } .all ol li.current{ background:yellow; } </style> <script src="js/匀速运动.js"></script> <script> function $(id){ return document.getElementById(id); } window.onload = function(){ var ul = $('ul'); var all = $('all'); var imgs = ul.getElementsByTagName('img'); var ol = document.createElement('ol'); all.appendChild(ol); for(var i=0;i<imgs.length;i++){ var li = document.createElement('li'); li.innerHTML = i+1; li.setAttribute('index',i); ol.appendChild(li); } ol.childNodes[0].className = 'current'; var olLis = ol.children; for(var i=0;i<olLis.length;i++){ olLis[i].onmouseover = function(){ for(var j=0;j<olLis.length;j++){ olLis[j].className = ''; } this.className = 'current'; var index = -500*this.getAttribute('index'); animate(ul,index,20,10); key=this.getAttribute('index'); squre = key; } } ul.appendChild(ul.children[0].cloneNode(true)); var timer=null; var key=0; var squre = 0; timer=setInterval(autoPlay, 1000); function autoPlay(){ key++; //记录图片 squre++;//记录导航条 if(key>olLis.length){ key=1; ul.style.left = 0 + 'px'; } if(squre>=olLis.length){ squre = 0; } animate(ul,-500*key,20,10); for(var i=0;i<olLis.length;i++){ olLis[i].className = ''; } olLis[squre].className = 'current'; } all.onmouseover = function(){ clearInterval(timer); } all.onmouseout = function(){ timer=setInterval(autoPlay, 1000); } } </script> </head> <body> <div class="all" id='all'> <div class="screen"> <ul id="ul"> <li><img src="images/taobao/1.jpg" width="500" height="200" /></li> <li><img src="images/taobao/2.jpg" width="500" height="200" /></li> <li><img src="images/taobao/3.jpg" width="500" height="200" /></li> <li><img src="images/taobao/4.jpg" width="500" height="200" /></li> <li><img src="images/taobao/5.jpg" width="500" height="200" /></li> </ul> </div> </div> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍原生JS实现匀速图片轮播动画,包括了原生JS实现匀速图片轮播动画的使用技巧和注意事项,需要的朋友参考一下 JS实现轮播图实现结果图: 需求: 1 根据图片动态添加小圆点 2 目标移动到小圆点轮播图片 3 鼠标离开图片,定时轮播图片;鼠标在图片上时暂停 4 左右两侧可点击轮播图片 一、布局部分 html部分 css部分 JS部分 1这是匀速动画函数的封装 轮播图封装函数: 精
本文向大家介绍vue实现匀速轮播效果,包括了vue实现匀速轮播效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了vue实现匀速轮播效果的具体代码,供大家参考,具体内容如下 不多描述了 直接代码吧 关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍js手动播放图片实现图片轮播效果,包括了js手动播放图片实现图片轮播效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js图片轮播具体实现代码,供大家参考,具体内容如下 一、html代码部分(et.thtml): 二、css代码部分(styleet,css): 三、js代码部分(et.js): 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教
本文向大家介绍js实现从右往左匀速显示图片(无缝轮播),包括了js实现从右往左匀速显示图片(无缝轮播)的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js实现从右往左匀速显示图片的具体代码,供大家参考,具体内容如下 前言: 匀速显示图片,一般用于重复显示公司活动系列图片 背景图片: 运行效果: 精彩专题分享:jQuery图片轮播 JavaScript图片轮播 Bootstrap图片轮
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章。欢迎在GitHub上关注我,一起入门和进阶前端。 以下是正文。 前言 JS动画的主要内容如下: 1、三大家族和一个事件对象: 三大家族:offset/scroll/client。也叫三大系列。 事件对象/event(事件被触动时,鼠标和键盘的状态)(通过属性控制)。 2、动画(闪现/匀速/缓动) 3、冒泡/兼容/封装 4、正则 off
本文向大家介绍原生js实现轮播图,包括了原生js实现轮播图的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js轮播图的具体实现代码,供大家参考,具体内容如下 CSS: html: js: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。