基于javascript實現(xiàn)移動端輪播圖效果
更新時間:2020年12月21日 15:58:37 作者:A.香辣雞腿堡
這篇文章主要為大家詳細介紹了基于javascript實現(xiàn)移動端輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了js實現(xiàn)移動端輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下
插件使用:
1.zepto.js
2.touch.js
實現(xiàn)效果
html部分:
<!-- 結(jié)構(gòu) --> <!-- li*6>a[href=#]>img[src=./images/$.jpg] --> <div class="box"> <ul> <!-- 為了無縫連接,我們在圖片這里前后增加了2個圖片 --> <li> <a href="#" ><img src="./images/6.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/1.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/2.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/3.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/4.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/5.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/6.jpg" alt=""></a> </li> <li> <a href="#" ><img src="./images/1.jpg" alt=""></a> </li> </ul> </div>
css部分:
* { margin: 0; padding: 0; } ul { list-style: none; } .box { width: 100%; overflow: hidden; } ul { /* 把li變成8張之后,需要,把ul的寬度變寬 */ width: 800%; /* transition: all 1s; */ } li { float: left; width: 12.5%; } img { width: 100%; }
js部分:
//獲取DOM var box = $(".box"); var img = $("ul img"); var ul = $("ul"); var imgWidth = img.width(); var index = 1; var right = index * imgWidth; ul.css("transform", `translateX(-${right}px)`); setTimeout(function() { ul.css("transition", "all 500ms"); }, 100); //往左滑,坐標在增大 box.on("swipeLeft", function() { index++; // if (index == img.length) { // index = 0; // } var left = index * imgWidth; ul.css("transform", `translateX(-${left}px)`); }); //往左滑,坐標在增大 box.on("swipeRight", function() { index--; // if (index == -1) { // index = img.length - 1; // } var right = index * imgWidth; ul.css("transform", `translateX(-${right}px)`); }); //過渡結(jié)束之后時進行 ul.on("transitionend", function() { //1.判讀 index //往左面滑(滑倒倒數(shù)第一張的時候,其實顯示的已經(jīng)是用戶想看的第一張) if (index == img.length - 1) { index = 1; //index修改完畢之后需要重新執(zhí)行一遍 var right = index * imgWidth; ul.css("transform", `translateX(-${right}px)`); //2.取消過渡效果 ul.css("transition", "none"); //3.已經(jīng)判斷完畢了,重新打開過渡效果 //這里設(shè)置一個1毫秒的延遲,否則會一起進行 setTimeout(function() { ul.css("transition", "all 500ms"); }, 1); } //1.判讀 index //往右面滑(滑倒index為0的時候,顯示的是客戶想看的第6張圖) if (index == 0) { //2.取消過渡效果 ul.css("transition", "none"); index = img.length - 2; //index修改完畢之后需要重新執(zhí)行一遍 var left = index * imgWidth; ul.css("transform", `translateX(-${left}px)`); //延遲開啟過渡效果 setTimeout(function() { ul.css("transition", "all 500ms"); }, 1) } })
代碼目前就分享到這里,歡迎大家有問題積極評論。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實現(xiàn)文件下載并重命名代碼實例
這篇文章主要介紹了JavaScript實現(xiàn)文件下載并重命名代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-12-12Java通過WebSocket實現(xiàn)異步導(dǎo)出解決思路
這篇文章主要介紹了通過WebSocket實現(xiàn)異步導(dǎo)出,本篇文章記錄大批量數(shù)據(jù)導(dǎo)出時間過長,導(dǎo)致接口請求超時問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-01-01