js仿小米官网图片轮播特效
小米官网给我的感觉是大气、干净。很多特效的加入让人觉得耳目一新,big满满。 看到他们首页的轮播图实现挺有意思,于是自己模仿着写了一个。
大致的感觉出来了,贴个图先:
通过前端神器chrom的F12观察小米官网的html代码,不难看到他们使用5个div包裹图片并使用了定位通过z-index来控制div层级,通过控制每个div的opacity属性和display属性进行元素的显示、隐藏。
截图如下(红框内的opacity属性):
好的,实现的手段知道了,那么页面布局先搞出来。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <title>Mking_js_</title> <script type="text/javascript" src="js/moveopacity_1.js"></script> <style type="text/css"> #warp{ width:800px; height: 400px; margin: 20px auto; position: relative;} #imgWarp{ width:600px; height: 400px; position: absolute; top:0; left: 100px; display: inline-block; } .btn:hover{cursor: pointer;} .btn{line-height: 30px; text-align: center;font-size: 25px; font-weight: bold; color: #fff;width:80px; height: 30px;top:185px;background: #5f7c8a;position: absolute; border-radius: 3px; } .btn:nth-of-type(1){ left: 0; } .btn:nth-of-type(2) { right: 0; } img { position: absolute; width:600px; height: 400px; background-size:contain; opacity: 0; display: none; z-index: 0; } img:nth-of-type(1) { opacity: 1; display: block; z-index:5; } .links{ width:300px; height: 30px; position: absolute; right:100px; bottom: 10px; z-index: 10; } em{font-style: normal; display: inline-block; height: 30px; width: 30px; margin-right: 15px; border: 1px solid #000000; vertical-align: top; line-height: 30px; font-size: 20px; text-align: center;color: #fff; font-weight: bold; border-radius: 50%; background-color: #008000; border-color: #c0c0c0; box-sizing: border-box; } em.active{ background-color: #fff; color: #000000; } </style> </head> <body> <div id="warp"> <div id="imgWarp" > <img id="img1" src="product/1.jpg" TITLE="img1" /> <img id="img2" src="product/2.jpg" TITLE="img2"/> <img id="img3" src="product/3.jpg" TITLE="img3"/> <img id="img4" src="product/4.jpg" TITLE="img4"/> <img id="img5" src="product/5.jpg" TITLE="img5" /> </div> <span class="btn" id="left">left</span> <span class="btn" id="right">right</span> <div class="links"> <em class="active"></em> <em></em> <em></em> <em></em> <em></em> </div> </div> </body> </html>
结构已经有了下面就是添加js让它动起来。
页面中的js:
window.onload = function(){ var oLeft = document.getElementById("left"); var oRight = document.getElementById("right"); var oWarp = document.getElementById("imgWarp"); var aImg = oWarp.getElementsByTagName("img"); var aEm = document.getElementsByTagName("em"); var i = 5; btn = true; oLeft.onclick = function(){ clearInterval(autoTimer); if(btn){ btn=false; fnAutoLeft(); } }; function fnAutoLeft(){ var a = i % 5; i-=1; var b = i % 5; startOpacMove(aImg[a],0,aImg[b],100); setStyle(b); } oRight.onclick = function(){ if(btn){ //单位时间内只能触发一次元素的显示隐藏 clearInterval(autoTimer); btn=false; fnAutoRight(); } }; var count =0; function fnAutoRight(){ var a = i % 5; i+=1; var b = i % 5; startOpacMove(aImg[a],0,aImg[b],100); setStyle(b); if(i==10){ i=5; for(var j = 0;j<aImg.length;j++){ if(j==0){ aImg[0].style.cssText ="opacity: 1; z-index: 5; display: block;"; } else{ aImg[j].style.cssText ="opacity: 0; z-index: 0; display: none;"; } } } } var autoTimer = setInterval(fnAutoRight,5000); function setStyle(a){ for(var i=0;i<aEm.length;i++){ aEm[i].className=""; } aEm[a].className="active"; } }
运动的js:
function startOpacMove(obj1,tag1,obj2,tag2) { var iCur1 = 0; var iCur2 = 0; var iTimer = null; var iSpeed1 = -2; var iSpeed2 = 2; clearInterval(iTimer); iTimer = setInterval(function(){ var iBtn = true; iCur1 = css(obj1,'opacity')*100; iCur2 = css(obj2,'opacity')*100; iCur1 = Math.floor(iCur1); iCur2 = Math.floor(iCur2); if(iCur1 != tag1 && iCur2 != tag2){ iBtn = false; obj1.style.opacity = (iCur1+iSpeed1)/100; // console.log("隐藏元素时候的透明度值:"+(iCur1+iSpeed1)/100); obj1.style.filter = 'alpha(opacity='+(iCur1+iSpeed1)+')'; obj1.style.zIndex = 0; obj2.style.opacity = (iCur2+iSpeed2)/100; obj2.style.filter = 'alpha(opacity='+(iCur2+iSpeed2)+')'; obj2.style.zIndex = 5; obj2.style.display ="block"; } if(iBtn){ clearInterval(iTimer); obj1.style.display ="none"; obj1.style.opacity =0; obj2.style.opacity =1; btn = true; } },10); } function css(obj,attr){ if(obj.currentStyle){ //当前浏览器下存在currentStyle属性 return obj.currentStyle[attr]; }else{ return getComputedStyle(obj,false)[attr]; } }
看下js代码是如何让图画动起来的
思考一个问题:画面是如何向左向右切换的,完成这一步的必要条件是什么。假设当前显示的第一张图,向右切换时隐藏第一张图显示第二张图,那么需要做的就是让索引为0的图片隐藏,索引为1的图片显示,再次点击向右按钮索引为1的图片隐藏索引为2的图片显示,后面的情况依次类推,需要获取的索引为0,1,2,3,4。最后注意下右侧的边界问题就OK了。
好的,贴代码:
var i = 5; function fnAutoRight(){ var a = i % 5; i+=1; var b = i % 5; }
用变量 i 对5取余,得到的值是0-4的数,刚好是我们想要的结果,对应的a、b也刚好是想要隐藏、显示的图片的索引。再调用写好的运动js、下方显示当前图片位置函数,那么向右这一块就OK了。
图片向左移动,向下我们需要隐藏显示的图片索引是什么,假设当前是第一张图片点击向左的时候,隐藏的图片索引为0,显示的图片索引为4,再次点击隐藏的索引为4显示的为3。显而易见,我们需要的索引为0、4、3、2、1。
代码如下:
var i=5; function fnAutoLeft(){ var a = i % 5; i-=1; var b = i % 5; }
同样是i=5,然后对5取余,得到的a为当前需要隐藏的图片索引,让i减一之后再对5取余得到的是需要显示的图片索引。这样向左的问题也就解决了。
在最后部分,写个setInterval定时播放的函数,然后设置一个间隔调用的时间,就完成了自动播放的功能。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
- 本篇文章主要分享了通过window.navigator来判断浏览器及其版本信息的实例代码。具有一定的参考价值,下面跟着小编一起来看下吧...2017-01-23
- 这篇文章主要介绍了js如何实现浏览器打印功能,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-15
- 这篇文章主要给大家介绍了关于Nest.js参数校验和自定义返回数据格式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-28
- 下面小编就为大家带来一篇利用JS实现点击按钮后图片自动切换的简单方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2016-10-25
- 作为前端,一直以来都知道HTTP劫持与XSS跨站脚本、CSRF跨站请求伪造。防御这些劫持最好的方法是从后端入手,前端能做的太少。而且由于源码的暴露,攻击者很容易绕过防御手段。但这不代表我们去了解这块的相关知识是没意义的,本文的许多方法,用在其他方面也是大有作用。...2021-05-24
- 这篇文章主要介绍了js实现调用网络摄像头及常见错误处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-07
- 这篇文章主要为大家详细介绍了JS实现随机生成验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-06
- 这篇文章主要介绍了js组件SlotMachine实现图片切换效果制作抽奖系统的相关资料,需要的朋友可以参考下...2016-04-19
- 这篇文章主要介绍了基于JavaScript实现文字超出部分隐藏 的相关资料,需要的朋友可以参考下...2016-03-01
- 这篇文章主要为大家详细介绍了js实现列表按字母排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-08-11
- 这篇文章主要介绍了JS实现响应鼠标点击动画渐变弹出层效果代码,具有非常自然流畅的动画过度效果,涉及JavaScript针对鼠标事件的响应及页面元素样式的动态操作相关技巧,需要的朋友可以参考下...2016-03-28
- 本文给大家介绍的是nodejs实现使用阿里大鱼短信API发送消息的方法和代码,有需要的小伙伴可以参考下。...2016-01-20
- 系统的学习了一下angularjs,发现angularjs的有些思想根php的模块smarty很像,例如数据绑定,filter。如果对smarty比较熟悉的话,学习angularjs会比较容易一点,这篇文章给大家介绍angularjs filter用法详解,感兴趣的朋友一起学习吧...2015-12-29
- Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.这篇文章主要介绍了vue.js 表格分页ajax 异步加载数据的相关资料,需要的朋友可以参考下...2016-10-20
- 这次文章要给大家介绍的是node.JS md5加密中文与php结果不一致怎么办,不知道具体解决办法的下面跟小编一起来看看。 因项目需要,需要Node.js与PHP做接口调用,发现nod...2017-07-06
- 这篇文章主要为大家详细介绍了js实现上传图片及时预览的相关资料,具有一定的参考价值,感兴趣的朋友可以参考一下...2016-05-09
- 为了网站的安全性,很多朋友都把密码设的比较复杂,但是如何密码不能明显示,不知道输的是对是错,为了安全起见可以把密码显示的,那么基于js代码如何实现的呢?下面通过本文给大家介绍JavaScript实现表单密码的隐藏和显示,需要的朋友参考下...2016-03-03
- 这篇文章主要给大家介绍了一个关于JS正则匹配的踩坑记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-13
- v-for标签可以用来遍历数组,将数组的每一个值绑定到相应的视图元素中去,下面这篇文章主要给大家介绍了关于在Vue.js中轻松解决v-for执行出错的三个方案,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。...2017-06-15
- 使用require('crypto')调用加密模块。加密模块需要底层系统提供OpenSSL的支持。它提供了一种安全凭证的封装方式,可以用于HTTPS安全网络以及普通HTTP连接。该模块还提供了一套针对OpenSSL的hash(哈希),hmac(密钥哈希),cipher...2014-06-07