JS實現(xiàn)自動輪播圖效果(自適應(yīng)屏幕寬度+手機(jī)觸屏滑動)
1、本文使用js+jQuery實現(xiàn)輪播圖,需要引用jquery包,另種實現(xiàn)分別是animate實現(xiàn)自適應(yīng)的輪播,以及transform平滑輪播(在注釋代碼中)。
2、代碼中的圖片大家自己更換就可以了,樣式和邏輯均寫在js里。
3、html標(biāo)簽代碼,js代碼
<div class="slider"> //輪播箭頭 <p class="lastpic"><img src="../images/prev.png"></p> <p class="nextpic"><img src="../images/next.png"></p> //輪播圖片 <ul id="slides" class="slides clearfix"> <li><img class="responsive" src="../images/wrap-page.jpg" alt="暫無圖片"></li> <li><img class="responsive" src="../images/wrap-page.jpg" alt="暫無圖片"></li> <li><img class="responsive" src="../images/wrap-page.jpg" alt="暫無圖片"></li> <li><img class="responsive" src="../images/wrap-page.jpg" alt="暫無圖片"></li> </ul> </div>
<script type="text/javascript"> $(document).ready(function() { var len = $(".slider li").length-1; //給slider設(shè)置樣式 $(".slider").css({ "width":"100%", "height": "inherit", "overflow": "hidden", "display":"inline-block" }); //給ul設(shè)置寬度 $(".slides").css({ "position": "relative", "width":((len+1)*100).toString()+"%", "margin":"0", "padding":"0"}); //給li設(shè)置百分比寬度 $(".slides li").css({ "width":(100/(len+1)).toString()+"%", "float":"left" }); //給圖片設(shè)置寬度 $(".responsive").css({ "width":"100%", "height":"inherit" }); //控制點(diǎn)樣式 $(".slider p").css({ "position": "absolute", "z-index":"999", "cursor": "pointer" }); $(".slider .lastpic").css({ "left":"0", "margin-top":"7%" }); $(".slider .nextpic").css({ "right":"0", "margin-top":"7%" }); //animate移動 var i = 0; $(".nextpic").click(function(){ moveNext(i); }); $(".lastpic").click(function(){ moveLast(i); }); //自動輪播 var timer = setInterval(function(){ moveNext(i); },5000); moveNext = function(n){ if(n==len){ i=-1; $(".slider .slides").animate({right: ""},800); }else{ $(".slider .slides").animate({right:((n+1)*100).toString()+"%"}, 800); } i++; } moveLast = function(n){ if(n==0){ i=len+1; $(".slider .slides").animate({right:(len*100).toString()+"%"}, 800); }else{ $(".slider .slides").animate({right:((n-1)*100).toString()+"%"}, 800); } i--; } //手機(jī)觸摸效果 var startX,endX,moveX; function touchStart(event){ var touch = event.touches[0]; startX = touch.pageX; } function touchMove(event){ var touch = event.touches[0]; endX = touch.pageX; } function touchEnd(event){ moveX = startX - endX; if(moveX>50){ moveNext(i); }else if(moveX<-50){ moveLast(i); } } document.getElementById("slides").addEventListener("touchstart",touchStart,false); document.getElementById("slides").addEventListener("touchmove",touchMove,false); document.getElementById("slides").addEventListener("touchend",touchEnd,false); //transition移動固定寬度,無法自適應(yīng) // $(".nextpic").click(function(){ // if(i==len){ // i=-1; // $(".slider .slides").css({ // 'transition-timing-function':'linear', // 'transition-duration':'800ms', // 'transform':'translateX(0px)' // }) // }else{ // $(".slider .slides").css({ // 'transition-timing-function':'linear', // 'transition-duration':'800ms', // 'transform':'translateX(-'+(i+1)*width+'px)' // }) // } // i++; // }); // $(".lastpic").click(function(){ // if(i==0){ // i=len+1; // $(".slider .slides").css({ // 'transition-timing-function':'linear', // 'transition-duration':'800ms', // 'transform':'translateX(-'+len*width+'px)' // }) // }else{ // $(".slider .slides").css({ // 'transition-timing-function':'linear', // 'transition-duration':'800ms', // 'transform':'translateX(-'+(i-1)*width+'px)' // }) // } // i--; // }) }); </script>
以上所述是小編給大家介紹的JS實現(xiàn)自動輪播圖效果(自適應(yīng)屏幕寬度+手機(jī)觸屏滑動),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
javascript實現(xiàn)發(fā)送短信驗證碼案例
這篇文章主要為大家詳細(xì)介紹了javascript實現(xiàn)發(fā)送短信驗證碼案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07JavaScript調(diào)用Activex控件的事件的實現(xiàn)方法
最近在搞一個客戶端調(diào)用activex控件的開發(fā)。一些實現(xiàn)方法小結(jié),需要的朋友可以參考下。2010-04-04layer.open的自適應(yīng)及居中及子頁面標(biāo)題的修改方法
今天小編就為大家分享一篇layer.open的自適應(yīng)及居中及子頁面標(biāo)題的修改方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript進(jìn)階(四)原型與原型鏈用法實例分析
這篇文章主要介紹了JavaScript原型與原型鏈,結(jié)合實例形式分析了JavaScript原型與原型鏈基本概念、原理、用法及操作注意事項,需要的朋友可以參考下2020-05-05流量統(tǒng)計器如何鑒別C#:WebBrowser中偽造referer
這篇文章主要介紹了流量統(tǒng)計器如何鑒別C#:WebBrowser中偽造referer,需要的朋友可以參考下2015-01-01javascript設(shè)計模式 – 迭代器模式原理與用法實例分析
這篇文章主要介紹了javascript設(shè)計模式 – 迭代器模式原理與用法,結(jié)合實例形式分析了javascript迭代器模式相關(guān)概念、原理、用法及操作注意事項,需要的朋友可以參考下2020-04-04