原生JS實(shí)現(xiàn)層疊輪播圖
更新時(shí)間:2017年05月17日 08:51:43 作者:Glunefish
這篇文章主要為大家詳細(xì)介紹了原生JS層疊輪播圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
又是輪播?沒(méi)錯(cuò),換個(gè)樣式玩輪播。
HTML:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>wtf</title> </head> <body> <div class="container"> <div class="box"> <img class="front" src="img/A.jpg" alt="PIC"> <img class="back" src="img/B.jpg" alt="PIC"> <img class="active" src="img/C.jpg" alt="PIC"> <div class="btns"> <span class="btn"><</span> <span class="btn">></span> </div> </div> </div> </body> </html>
CSS:
<style> .box {width: 1200px; height: 300px; transform-style: perserve-3d; margin: 50px auto; position: relative;} .box img{width:600px; position: absolute; top: 60px; transition:all .3s linear;} .box:hover .btn{opacity: 1;} .front {left: 0px;} .back {left: 600px;} .active {left: 300px; transform: scale(1.5); z-index: 10;} .btns .btn {width: 60px; height: 60px; display: block; position: absolute; background-color: rgba(0,0,0,.5); font-size: 50px; font-family: "微軟雅黑"; color:rgba(255,255,255,.5); line-height: 55px; text-align: center; cursor: pointer; z-index: 100; opacity: 0; transition:opacity .3s linear;} .btns .btn:first-child {top: 125px;} .btns .btn:last-child {top: 125px; right: 0px;} </style>
JS:
<script> onload = function(){ var btns = document.getElementsByClassName('btn'), imgs = document.getElementsByClassName('box')[0].getElementsByTagName('img'); var index = 2, front = 0, back = 0, offset = false, timer = setInterval(timer,5000); for(var i=0;i<btns.length;i++){ (function(i){ btns[i].onclick = function(){click(i)}; })(i); btns[i].onmouseover = function(){ offset = true; } btns[i].onmouseout = function(){ offset = false; } } for(var i=0;i<imgs.length;i++){ imgs[i].onmouseover = function(){ offset = true; } imgs[i].onmouseout = function(){ offset = false; } } function timer(){ console.log(offset) if(offset){ return; } else{ click(1) } } function click(x){ imgs[index].setAttribute('class',''); if(x === 0){ if(--index < 0){ index = --imgs.length; } front = back = index; if(++front > --imgs.length){front = 0} if(--back < 0){back = --imgs.length} imgs[front].style.zIndex = '1'; imgs[back].style.zIndex = '0'; } else{ if(++index > --imgs.length){ index = 0; } front = back = index; if(++front > --imgs.length){front = 0} if(--back < 0){back = --imgs.length} imgs[front].style.zIndex = '0'; imgs[back].style.zIndex = '1'; } imgs[index].style.zIndex = '10'; imgs[front].setAttribute('class','front') imgs[back].setAttribute('class','back') imgs[index].setAttribute('class','active'); } } </script>
精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- 原生js實(shí)現(xiàn)輪播圖的示例代碼
- 原生js實(shí)現(xiàn)無(wú)限循環(huán)輪播圖效果
- 原生js實(shí)現(xiàn)移動(dòng)開(kāi)發(fā)輪播圖、相冊(cè)滑動(dòng)特效
- 原生js實(shí)現(xiàn)無(wú)縫輪播圖效果
- 原生js實(shí)現(xiàn)旋轉(zhuǎn)木馬輪播圖效果
- 原生JS輪播圖插件
- 原生JS京東輪播圖代碼
- 原生js實(shí)現(xiàn)網(wǎng)易輪播圖效果
- 原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果
- 無(wú)限循環(huán)輪播圖之運(yùn)動(dòng)框架(原生JS實(shí)現(xiàn))
- 原生JS實(shí)現(xiàn)的輪播圖功能詳解
相關(guān)文章
Javascript循環(huán)刪除數(shù)組中元素的幾種方法示例
這篇文章主要給大家介紹了關(guān)于Javascript循環(huán)刪除數(shù)組中元素的幾種方法,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-05-05WdatePicker.js時(shí)間日期插件的使用方法
本篇文章主要介紹了WdatePicker.js時(shí)間日期插件的使用方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07js在ie下打開(kāi)對(duì)話窗口的方法小結(jié)
下面小編就為大家?guī)?lái)一篇js在ie下打開(kāi)對(duì)話窗口的方法小結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10IE瀏覽器打印的頁(yè)眉頁(yè)腳設(shè)置解決方法
IE瀏覽器打印的頁(yè)眉頁(yè)腳設(shè)置解決方法2009-12-12