您好,登錄后才能下訂單哦!
這篇文章主要講解了“jquery怎么實現(xiàn)PC端輪播圖功能”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“jquery怎么實現(xiàn)PC端輪播圖功能”吧!
實現(xiàn)的效果:
1、自動輪播(輪播時間間隔在js代碼中自定義)
2、點擊左右側(cè)按鈕,實現(xiàn)手動切換
3、底部小圓點根據(jù)切換圖片的位置相應的顯示active狀態(tài)
4、鼠標經(jīng)過輪播圖區(qū)域,停止輪播,離開輪播圖區(qū)域開始輪播
代碼目錄結(jié)果如下:
一、index.html
注:這里以5張圖片為例,頁面上真正輪播展示給用戶看到的是5張不同的圖片,但是為了輪播效果的連貫性,所以在第一張圖片前面添加上第五張圖片,在第五張圖片后面加上了第一張圖片,所以demo結(jié)構(gòu)里是7張圖片,每張圖片的尺寸必須都是一樣的哦(這里寬高尺寸是720*350px)。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>PC-jquery版輪播圖</title> <link rel="stylesheet" href="css/style.css" rel="external nofollow" > </head> <body> <div class="layout"> <h3 >PC-jquery版輪播圖</h3> <div class="slide" id="slide"> <div id="outer" class="outer"> <ul id="inner" class="inner"> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-5</p><img src="images/slide-5.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-1</p><img src="images/slide-1.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-2</p><img src="images/slide-2.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-3</p><img src="images/slide-3.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-4</p><img src="images/slide-4.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-5</p><img src="images/slide-5.jpg"></a></li> <li><a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><p>圖片-1</p><img src="images/slide-1.jpg"></a></li> </ul> <!--底部小圓點--> <ol class="dot" id="dot"> <li class="active"></li> <li></li> <li></li> <li></li> <li></li> </ol> </div> <!--左右兩側(cè)的點擊切換按鈕--> <div class="arrow-box"> <div class="arrow arrow-l" id="arrow_l">?</div> <div class="arrow arrow-r" id="arrow_r">?</div> </div> </div> </div> <script src="js/jquery.min.js"></script> <script src="js/index.js"></script> </body> </html>
二、style.css
* { margin: 0; padding: 0; box-sizing: border-box; } .layout { width: 1000px; margin: 30px auto; } ul,ol,li { list-style: none; } .slide { position: relative; width: 900px; margin:auto; } .slide .outer { position: relative; margin: 30px auto; width: 720px; height: 400px; overflow: hidden; } .slide .outer .inner { width: 5040px; height: 350px; position: absolute; left: -720px; top: 0; } .slide .outer .inner li { float: left; height: 350px; } .slide .outer .inner li a { display: block; position: relative; width: 100%; height: 100%; } .slide .outer .inner li a p { position: absolute; left: 0; bottom: 0; color: #fff; font-size: 18px; width: 720px; height: 80px; line-height: 80px; padding-left: 50px; background: linear-gradient(180deg,rgba(0,0,0,0), rgba(0,0,0,0.5)); } .slide .outer .dot { margin-top: 365px; text-align: center; } .slide .outer .dot li { height: 6px; width: 6px; border-radius: 3px; background-color: #d2cbcb; display: inline-block; margin: 0 3px; } .slide .outer .dot li.active { background-color: #6e5ca5; } .slide .arrow-box { position: absolute; width: 900px; height: 60px; top: 150px; left: 0; } .slide .arrow-box .arrow { width: 60px; height: 60px; line-height: 60px; text-align: center; border-radius: 30px; background-color: #dde2e6; font-size: 60px; color: #999; cursor: pointer; } .slide .arrow-box .arrow.arrow-l { float: left; } .slide .arrow-box .arrow.arrow-r { float: right; }
三、index.js
注:js代碼中,每個變量均已給了注釋。為了防止快速多次點擊,而出現(xiàn)動畫不停的現(xiàn)象,這里在每次切換圖片的時候先調(diào)用stop(false,true)。但是注意在向左側(cè)滾動的時候,滾動到最后一張圖圖片后,再次切換時就不要用stop(false,true),而是要瞬間定位到第一張圖片(其實是dom結(jié)構(gòu)中的第二張)的位置,同樣,向右側(cè)滾動時,當滾動到第一張圖片后,再次切換時就不用stop(false,true),而是要瞬間定位到最后一張圖片(其實是dom結(jié)構(gòu)中的倒數(shù)第二張)的位置。
var interval = 3000; //輪播間隔時間 var arrowL = $('#arrow_l'); //左側(cè)箭頭 var arrowR = $('#arrow_r'); //右側(cè)箭頭 var slideBox = $('#slide'); //輪播圖區(qū)域 var innerBox = $('#inner'); //內(nèi)層大盒子 var img = innerBox.children('li'); //每個圖片 var dot = $('#dot'); //小圓點盒子 var imgW = $(img[0]).outerWidth(); //每個li標簽的寬度 var imgCount = 5; //總圖片個數(shù)(不同圖片的個數(shù))(實際dom上是有7張) var i = 0; //初始化為第0張圖片 timer = null; //定時器 //自動輪播 timer = setInterval(function () { i++; innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300) dot.find('li').removeClass('active').eq(i-1).addClass('active') if(i > imgCount){ innerBox.animate({'left':-1*imgW+'px'},0); dot.find('li').removeClass('active').eq(0).addClass('active') i = 1; } },interval) //點擊右側(cè)箭頭,播放下一張 arrowR.click(function () { i++; innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300) dot.find('li').removeClass('active').eq(i-1).addClass('active') if(i > imgCount){ innerBox.animate({'left':-1*imgW+'px'},0); dot.find('li').removeClass('active').eq(0).addClass('active') i = 1; } }) //點擊左側(cè)箭頭,播放上一張 arrowL.click(function () { i--; innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300) dot.find('li').removeClass('active').eq(i-1).addClass('active') if(i < 1){ innerBox.animate({'left':-imgCount*imgW+'px'},0); dot.find('li').removeClass('active').eq(imgCount-1).addClass('active') i = imgCount; } }) //鼠標經(jīng)過輪播圖區(qū)域時,清除定時器,停止自動輪播 slideBox.mouseenter(function () { clearInterval(timer); }) //鼠標離開輪播圖區(qū)域時,重新啟動自動輪播 slideBox.mouseleave(function () { timer = setInterval(function () { i++; innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300) dot.find('li').removeClass('active').eq(i-1).addClass('active') if(i > imgCount){ innerBox.animate({'left':-1*imgW+'px'},0); dot.find('li').removeClass('active').eq(0).addClass('active') i = 1; } },interval) })
感謝各位的閱讀,以上就是“jquery怎么實現(xiàn)PC端輪播圖功能”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對jquery怎么實現(xiàn)PC端輪播圖功能這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。