原生JS實(shí)現(xiàn)圖片輪播切換效果
首先來(lái)分析一下輪播圖效果的實(shí)現(xiàn)原理:
1、父元素作為顯示窗口,大小固定超出部分隱藏,即設(shè)置overflow:hidden;
2、子元素存放圖片列表用ul,ul固定定位,參照為父元素,即父元素position:relative;ul元素position:absolute;
3、一個(gè)li即一張圖片的寬度為父元素的顯示寬度
4、初始時(shí),ul的left為0,這時(shí)第一張圖片即第一個(gè)li顯示
5、點(diǎn)擊下一張按鈕,將整個(gè)ul左移,使第二個(gè)li對(duì)齊父元素的左邊框,此時(shí)ul的left為負(fù)的一個(gè)li的寬度
6、點(diǎn)擊上一張按鈕,將整個(gè)ul右移
7、對(duì)特殊情況進(jìn)行處理,即第一張圖時(shí)點(diǎn)上一張,最后一張圖時(shí)點(diǎn)下一張
第一張圖時(shí)點(diǎn)上一張,我們滾動(dòng)到最后一張圖,整個(gè)ul左移,即把left值改為負(fù)的n-1張圖的寬度;
最后一張圖時(shí)點(diǎn)下一張,我們滾到第一張圖的位置,整個(gè)ul右移,即把left值改為0
用一張圖來(lái)幫助理解:
修改ul元素的left值很簡(jiǎn)單ul.style.left=設(shè)定值,就可以了,但我們想有一個(gè)滑動(dòng)的效果,那我們需要用setInterval來(lái)實(shí)現(xiàn)
最后的效果如下:
動(dòng)圖不能錄制太大CSDN有2M的限制_(:зゝ∠)_
下面放代碼
script部分
<script> window.onload= function () { var nav=document.getElementById("nav").getElementsByTagName("li"); var img=document.getElementById("imgList"); var prev=document.getElementById("prev"); var next=document.getElementById("next"); var index=0;//當(dāng)前圖片序列號(hào) var timer;//定時(shí)器名字 var iSpeed=-10;//滾動(dòng)的速度 function goRoll(){ timer=setInterval(function () { img.style.left=img.offsetLeft+iSpeed+'px'; var stop=-index*870+'px';//當(dāng)達(dá)到目標(biāo)位置是停止定時(shí)器 if(img.style.left==stop){ iSpeed=-10; clearInterval(timer); } },10) } // 上一張和下一張點(diǎn)擊效果 prev.onclick= function () { if(index==0){ index=2; iSpeed=-20; }else{ index--; iSpeed=10; } goRoll(); //img.style.left=-index*870+'px'; }; next.onclick= function () { if(index==2){ index=0; iSpeed=20; }else{ index++; iSpeed=-10; } goRoll(); //img.style.left=-index*870+'px'; }; } </script>
html放一下
<div class="panel center-panel bc_rice"> <div class="panel-box"> <a class="prev-btn" id="prev"></a> <div class="img-box"> <div class="list-box"> <ul class="img-list" id="imgList"> <li> <img src="img/c1.jpg"/> </li> <li> <img src="img/c2.jpg"/> </li> <li> <img src="img/c3.jpg"/> </li> </ul> </div> </div> <a class="next-btn" id="next"></a> <img class="mT20" src="img/shadow1.png"/> </div> <div class="center-line bc_brown"></div> </div>
CSS放一下
.fb{font-weight:bold;} .c_fff{color:#fff;} .f24{font-size:24px;} .f72{font-size:72px;} .lh40{line-height:40px;} .bc_brown{background:#533d3b;} .bc_green{background:#74cdab;} .bc_rice{background:#ecf1c8;} .bc_beige{background:#d1d5b0;} .mT10{margin-top:10px;} .mT20{margin-top:20px;} .mT30{margin-top:30px;} .mT40{margin-top:40px;} .tc{text-align:center;} .dblock{display:block;} .clearfix:after{content:'';display:block;visibility:hidden;clear:both;line-height:0;font-size:0;} .clearfix{zoom:1;} html,body{width:100%;height:100%;font-size:14px;font-family:Myriad Pro;color:#433c3c;} div,p,a,span,ul,li,em{margin:0;padding:0;} ul li{list-style-type:none;} a:hover{cursor:pointer;} /*main-panel*/ .main-panel{width:100%;min-width:1030px;margin:0 auto;} .main-panel .panel{width:100%;} .main-panel .panel .line{width:100%;height:23px;background:url('../img/line.png');} .main-panel .panel .panel-box{width:960px;height:100%;margin:0 auto;overflow:hidden;position:relative;}
.center-panel{height:510px;position:relative;} .center-panel .panel-box{width:990px;z-index:1000;} .center-panel .center-line{height:76px;position:absolute;width:100%;top:200px;z-index:10;} .center-panel .panel-box a{width:51px;height:82px;display:block;position:absolute;top:200px;} .center-panel .prev-btn{background:url('../img/Button-left.png');left:0;} .center-panel .next-btn{background:url('../img/Button-right.png');right:0;} .center-panel .img-box{width:940px;height:366px;background:url('../img/shadow.png');margin-top:45px;margin-left:10px;overflow:hidden;} .center-panel .list-box{width:870px;height:334px;margin:16px auto;overflow:hidden;position:relative;} .center-panel .img-list{width:4000px;height:334px;position:absolute;left:0;} .center-panel .img-list li{width:870px;height:100%;float:left;}
因?yàn)槲覍?xiě)了一整個(gè)頁(yè)面都放出來(lái)沒(méi)啥用,所以我只截取了用到的部分。
現(xiàn)在還是有些問(wèn)題的,比如如果點(diǎn)擊過(guò)快是會(huì)出問(wèn)題的,這個(gè)以后看看能不能完善。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js實(shí)現(xiàn)支持手機(jī)滑動(dòng)切換的輪播圖片效果實(shí)例
- js圖片輪播手動(dòng)切換效果
- vue.js+elementUI實(shí)現(xiàn)點(diǎn)擊左右箭頭切換頭像功能(類似輪播圖效果)
- 原生js實(shí)現(xiàn)圖片層疊輪播切換效果
- javascript實(shí)現(xiàn)圖片自動(dòng)和可控的輪播切換特效
- Bootstrap 最常用的JS插件系列總結(jié)(圖片輪播、標(biāo)簽切換等)
- JS仿京東移動(dòng)端手指撥動(dòng)切換輪播圖效果
- js實(shí)現(xiàn)淡入淡出輪播切換功能
- javascript五圖輪播切換實(shí)用版
- js實(shí)現(xiàn)圖片輪播切換效果
相關(guān)文章
js 將線性數(shù)據(jù)轉(zhuǎn)為樹(shù)形的示例代碼
這篇文章主要介紹了js 將線性數(shù)據(jù)轉(zhuǎn)為樹(shù)形的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05JS 中document.URL 和 windows.location.href 的區(qū)別
實(shí)際上,document 和 windows 這兩個(gè)對(duì)象的區(qū)別已經(jīng)包含了這個(gè)問(wèn)題的答案。2009-11-11JavaScript必知必會(huì)(二) null 和undefined
這篇文章主要介紹了JavaScript必知必會(huì)(二) null 和undefined的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06深入了解JavaScript中遞歸的理解與實(shí)現(xiàn)
本文將通過(guò)遞歸的經(jīng)典案例:求斐波那契數(shù)來(lái)講解遞歸,通過(guò)畫(huà)遞歸樹(shù)的方式來(lái)講解其時(shí)間復(fù)雜度和空間復(fù)雜度以及遞歸的執(zhí)行順序,感興趣的可以了解一下2022-06-06JavaScript操作選擇對(duì)象的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇JavaScript操作選擇對(duì)象的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧2016-05-05js實(shí)現(xiàn)固定寬高滑動(dòng)輪播圖效果
本文主要分享了js實(shí)現(xiàn)PC固定寬高滑動(dòng)輪播圖效果的示例代碼。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01