基于javascript實(shí)現(xiàn)移動(dòng)端輪播圖效果
本文實(shí)例為大家分享了js實(shí)現(xiàn)移動(dòng)端輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下
插件使用:
1.zepto.js2.touch.js
實(shí)現(xiàn)效果
html部分:
<!-- 結(jié)構(gòu) --> <!-- li*6>a[href=#]>img[src=./images/$.jpg] --> <div class='box'> <ul> <!-- 為了無(wú)縫連接,我們?cè)趫D片這里前后增加了2個(gè)圖片 --> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/6.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/1.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/2.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/3.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/4.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/5.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/images/6.jpg' alt=''></a> </li> <li> <a href='http://www.hdgsjgj.cn/bcjs/14256.html#' ><img src='http://www.hdgsjgj.cn/bcjs/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); //往左滑,坐標(biāo)在增大 box.on('swipeLeft', function() { index++; // if (index == img.length) { // index = 0; // } var left = index * imgWidth; ul.css('transform', `translateX(-${left}px)`); }); //往左滑,坐標(biāo)在增大 box.on('swipeRight', function() { index--; // if (index == -1) { // index = img.length - 1; // } var right = index * imgWidth; ul.css('transform', `translateX(-${right}px)`); }); //過(guò)渡結(jié)束之后時(shí)進(jìn)行 ul.on('transitionend', function() { //1.判讀 index //往左面滑(滑倒倒數(shù)第一張的時(shí)候,其實(shí)顯示的已經(jīng)是用戶想看的第一張) if (index == img.length - 1) { index = 1; //index修改完畢之后需要重新執(zhí)行一遍 var right = index * imgWidth; ul.css('transform', `translateX(-${right}px)`); //2.取消過(guò)渡效果 ul.css('transition', 'none'); //3.已經(jīng)判斷完畢了,重新打開過(guò)渡效果 //這里設(shè)置一個(gè)1毫秒的延遲,否則會(huì)一起進(jìn)行 setTimeout(function() { ul.css('transition', 'all 500ms'); }, 1); } //1.判讀 index //往右面滑(滑倒index為0的時(shí)候,顯示的是客戶想看的第6張圖) if (index == 0) { //2.取消過(guò)渡效果 ul.css('transition', 'none'); index = img.length - 2; //index修改完畢之后需要重新執(zhí)行一遍 var left = index * imgWidth; ul.css('transform', `translateX(-${left}px)`); //延遲開啟過(guò)渡效果 setTimeout(function() { ul.css('transition', 'all 500ms'); }, 1) } })
代碼目前就分享到這里,歡迎大家有問(wèn)題積極評(píng)論。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 如何對(duì)php程序中的常見漏洞進(jìn)行攻擊2. PHP循環(huán)與分支知識(shí)點(diǎn)梳理3. jsp EL表達(dá)式詳解4. Spring MVC+ajax進(jìn)行信息驗(yàn)證的方法5. JavaWeb Servlet中url-pattern的使用6. Ajax提交post請(qǐng)求案例分析7. Ajax請(qǐng)求超時(shí)與網(wǎng)絡(luò)異常處理圖文詳解8. ASP中格式化時(shí)間短日期補(bǔ)0變兩位長(zhǎng)日期的方法9. JSP之表單提交get和post的區(qū)別詳解及實(shí)例10. ThinkPHP5 通過(guò)ajax插入圖片并實(shí)時(shí)顯示(完整代碼)
