JavaScript超詳細(xì)實(shí)現(xiàn)網(wǎng)頁(yè)輪播圖
前言:
在網(wǎng)頁(yè)中,我們經(jīng)常會(huì)看到各種輪播圖的效果,它們到底是怎樣實(shí)現(xiàn)的呢?今天,我們就一起來(lái)看一下!首先,我們需要準(zhǔn)備若干張圖片,在這里我準(zhǔn)備了五張圖片。
功能需求:
- 鼠標(biāo)經(jīng)過(guò)輪播圖模塊,左右按鈕顯示,離開(kāi)隱藏左右按鈕。
- 點(diǎn)擊右側(cè)按鈕一次,圖片往左播放一張,以此類推, 左側(cè)按鈕同理。
- 圖片播放的同時(shí),下面小圓圈模塊跟隨一起變化。
- 點(diǎn)擊小圓圈,可以播放相應(yīng)圖片。
- 鼠標(biāo)不經(jīng)過(guò)輪播圖, 輪播圖也會(huì)自動(dòng)播放圖片。
- 鼠標(biāo)經(jīng)過(guò),輪播圖模塊, 自動(dòng)播放停止。
我們頁(yè)面布局如下所示:
接下來(lái)就一步步的實(shí)現(xiàn)功能
創(chuàng)建HTML頁(yè)面
實(shí)現(xiàn)流程是:先給定一個(gè)大盒子,為了方便后面盒子的定位操作,再給它一個(gè)相對(duì)定位,把圖片通過(guò)無(wú)序列表的形式添加進(jìn)大盒子中,因?yàn)槲覀円獙?shí)現(xiàn)的輪播圖效果是橫向的,所以我們可以給圖片添加float:left
屬性,又因?yàn)閳D片所在的ul不夠大,所以其他的圖片會(huì)被擠到下面,所以我們可以手動(dòng)修改圖片所在的ul的大小;接下來(lái)寫(xiě)一個(gè)無(wú)序列表用于放置小圓圈,通過(guò)絕對(duì)定位的方式將其定位到大盒子的下面,在將小圓圈加進(jìn)去,方便我們實(shí)現(xiàn)點(diǎn)擊對(duì)應(yīng)的小圓圈,就跳轉(zhuǎn)到相應(yīng)圖片的效果。然后將左右箭頭通過(guò)絕對(duì)定位分別定到大盒子兩側(cè)合適位置。最后,我們?cè)賹⒋蠛凶油饷娴膬?nèi)容隱藏掉。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <link rel="stylesheet" href="index.css" rel="external nofollow" > </head> <body> <div class="box"> <a href="" class = 'left jiantou'><</a> <a href="" class = 'right jiantou'>></a> <ul class = 'pic'> <li> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="./images/1.jpg" alt=""></a> </li> <li> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="./images/2.jpg" alt=""></a> </li> <li> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="./images/3.jpg" alt=""></a> </li> <li> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="./images/4.jpg" alt=""></a> </li> <li> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="./images/5.jpg" alt=""></a> </li> </ul> <ul class="lis"> <li></li> <li class = 'selected'></li> <li></li> <li></li> <li></li> </ul> </div> </body> </html>
css文件
*{ margin: 0; padding: 0; } li{ list-style: none; } .box{ position: relative; overflow: hidden; margin: 100px auto; width: 520px; height: 280px; background-color: red; } .jiantou{ font-size: 24px; text-decoration: none; display: block; text-align: center; width: 20px; height: 30px; line-height: 30px; background: rgba(158, 154, 154, 0.7); color: white; z-index: 999; } .left{ position: absolute; top: 125px; left: 0px; border-top-right-radius: 15px; border-bottom-right-radius: 15px; } .right{ position: absolute; top:125px; left: 500px; border-top-left-radius: 15px; border-bottom-left-radius: 15px; } img{ width: 520px; height: 280px; } .box .pic{ width: 600%; } .pic li { float: left; } .lis{ position: absolute; bottom: 15px; left: 50%; margin-left: -35px; width: 70px; height:13px; border-radius: 7px; background: rgba(158, 154, 154, 0.7); } .lis li { float: left; width: 8px; height: 8px; margin: 3px; border-radius: 50%; background-color: #fff; } .lis .selected{ background-color: cyan; }
此時(shí)頁(yè)面效果為:
實(shí)現(xiàn)js部分的功能
1、左右按鈕
當(dāng)鼠標(biāo)經(jīng)過(guò)輪播圖模塊,左右按鈕顯示,離開(kāi)隱藏左右按鈕。
首先,我們先通過(guò)display:none
讓我們初始的兩個(gè)箭頭隱藏;然后獲取兩個(gè)箭頭和大盒子,在給大盒子添加鼠標(biāo)經(jīng)過(guò)和鼠標(biāo)離開(kāi)事件。
如下所示:
var left = document.querySelector('.left'); var right = document.querySelector('.right'); var box = document.querySelector('.box'); box.addEventListener('mouseenter',function(){ left.style.display = 'block'; right.style.display = 'block'; }) box.addEventListener('mouseleave',function(){ left.style.display = 'none'; right.style.display = 'none'; })
實(shí)現(xiàn)效果為:
2、動(dòng)態(tài)生成小圓圈
先刪除掉所有的小圓圈的li,如圖所示:
因?yàn)槲覀儎?chuàng)建的小圓圈是根據(jù)圖片的張數(shù)決定的,所以我們的核心思路就是:小圓圈的個(gè)數(shù)要跟圖片張數(shù)一致,先得到ul里面圖片的張數(shù)(圖片放入li里面,所以就是li的個(gè)數(shù)),然后利用循環(huán)動(dòng)態(tài)通過(guò)創(chuàng)建節(jié)點(diǎn)createElement
(‘li’)和插入節(jié)點(diǎn) ul. appendChild(li)
生成小圓圈(這個(gè)小圓圈要放入ul里面)要注意第一個(gè)小圓圈需要添加selected類。
實(shí)現(xiàn)代碼為:
var pic = document.querySelector('.pic'); var lis = document.querySelector('.lis'); for(var i = 0;i<pic.children.length;i++){ var li = document.createElement('li'); lis.appendChild(li); } lis.children[0].className = 'selected';
實(shí)現(xiàn)效果為:
3、點(diǎn)擊小圓圈,小圓圈變色
在生成小li的同時(shí),根據(jù)排他思想,給小圓圈添加點(diǎn)擊事件,當(dāng)點(diǎn)擊對(duì)應(yīng)的小圓圈時(shí),讓其添加selected
類,其余的小圓圈刪除selected
類。
代碼為:
li.addEventListener('click',function(){ for(var i =0;i<lis.children.length;i++){ lis.childern[i].className = ''; } this.className = 'selected'; })
實(shí)現(xiàn)效果為:
4、點(diǎn)擊小圓圈滾動(dòng)圖片
這里就用到動(dòng)畫(huà)函數(shù),前面已經(jīng)講過(guò)怎樣封裝動(dòng)畫(huà)函數(shù),這里不在贅述,直接引用。但是要注意將動(dòng)畫(huà)函數(shù)的js文件放在我們index.js的上面。又因?yàn)橹挥刑砑恿硕ㄎ涣嗽夭趴梢允褂脛?dòng)畫(huà)函數(shù),我們還需要給pic這個(gè)ul添加定位。然后根據(jù)規(guī)律發(fā)現(xiàn): 點(diǎn)擊某個(gè)小圓圈 ,ul滾動(dòng)的距離為: 小圓圈的索引號(hào)乘以圖片的寬度。(因?yàn)閳D片是向左走,所以為負(fù)值)所以需要知道小圓圈的索引號(hào), 我們就可以在生成小圓圈的時(shí)候,給它設(shè)置一個(gè)自定義屬性,點(diǎn)擊的時(shí)候獲取這個(gè)自定義屬性。
先在生成li的時(shí)候設(shè)置索引:
li.setAttribute('index',i);
然后在給li添加點(diǎn)擊事件的時(shí)候獲得索引,并得到圖片寬度,調(diào)用動(dòng)畫(huà)函數(shù):
li.addEventListener('click',function(){ var boxWidth = box.offsetWidth; //獲得索引號(hào) var index = this.getAttribute('index'); for(var i = 0;i<lis.children.length;i++){ lis.children[i].className = ''; } this.className = 'selected'; animate(pic,-index*boxWidth) })
實(shí)現(xiàn)效果為:
5、點(diǎn)擊右側(cè)按鈕一次,就讓圖片滾動(dòng)一張。
可以直接給右側(cè)按鈕添加點(diǎn)擊事件,聲明一個(gè)變量num
, 點(diǎn)擊一次,自增1, 讓這個(gè)變量乘以圖片寬度,就是 ul 的滾動(dòng)距離。
var num = 0; right.addEventListener('click',function(){ num++; animate(pic,-num*boxWidth); })
實(shí)現(xiàn)效果為:
我們發(fā)現(xiàn),當(dāng)點(diǎn)擊右側(cè)按鈕時(shí),可以實(shí)現(xiàn)圖片的切換效果,但是當(dāng)點(diǎn)擊到最后一張圖片的時(shí)候,就會(huì)停留在顯頁(yè)面初始背景,并不美觀,所以我們就可以通過(guò)圖片無(wú)縫滾動(dòng)原理讓圖片無(wú)縫滾動(dòng),操作方法為。將.pic
列表里的第一個(gè)li通過(guò)cloneNode(true)
添加一份,然后通過(guò)appendChild()
復(fù)制到該列表的末尾,然后再在js頁(yè)面中給num
添加一個(gè)判斷條件,即當(dāng)num的值等于這個(gè)列表里面元素的個(gè)數(shù)-1的時(shí)候,讓ul移動(dòng)的距離變?yōu)?,并讓num等于0。
代碼為:
var first = pic.children[0].cloneNode(true); pic.appendChild(first); //右側(cè)按鈕的功能 var num = 0; right.addEventListener('click',function(){ if(num == pic.children.length-1){ pic.style.left = 0; num = 0; } num++; animate(pic,-num*boxWidth); })
實(shí)現(xiàn)效果為:
成功實(shí)現(xiàn)。
6、點(diǎn)擊右側(cè)按鈕, 小圓圈跟隨變化
需要進(jìn)行的操作是:再聲明一個(gè)變量circle,每次點(diǎn)擊右側(cè)按鈕時(shí)自增1,因?yàn)楫?dāng)我們左側(cè)按鈕點(diǎn)擊時(shí)也會(huì)實(shí)現(xiàn)該效果,也需要這個(gè)變量,因此要聲明全局變量。但是圖片有5張,我們小圓圈只有4個(gè)少一個(gè),必須加一個(gè)判斷條件,如果circle == 4就 從新復(fù)原為 0。
var num = 0; var circle = 0; right.addEventListener('click',function(){ if(num == pic.children.length-1){ pic.style.left = 0; num = 0; } num++; animate(pic,-num*boxWidth); circle++; if(circle == lis.children.length){ circle = 0; } for(var i =0;i<lis.children.length;i++){ lis.children[i].className = ''; } lis.children[circle].className = 'selected'; })
運(yùn)行結(jié)果為:
但是這樣還是有點(diǎn)小問(wèn)題的,當(dāng)我們讓小圓圈和右側(cè)按鈕結(jié)合起來(lái)使用的時(shí)候,就會(huì)發(fā)現(xiàn)錯(cuò)誤,如下:
當(dāng)我們點(diǎn)擊小圓點(diǎn)時(shí),也可以跳轉(zhuǎn)到相應(yīng)的圖片頁(yè),但當(dāng)我們繼續(xù)點(diǎn)擊右側(cè)按鈕時(shí),就會(huì)發(fā)現(xiàn)下面的小圓點(diǎn)和對(duì)應(yīng)的圖片不對(duì)應(yīng)了。這是我們我們的右側(cè)按鈕點(diǎn)擊事件時(shí)通過(guò)變量num來(lái)控制的,而num變量和小圓圈的點(diǎn)擊事件沒(méi)有任何關(guān)系,所以就存在差異。
我們的解決方案就是每次點(diǎn)擊小li時(shí),獲得它的索引號(hào),然后把num
和circle
的值改為得到的索引號(hào)的值,代碼為:
var index = this.getAttribute('index'); num = index; circle = index;
實(shí)現(xiàn)效果為:
7、左側(cè)按鈕功能制作
和右側(cè)按鈕做法類似,不在贅述,代碼如下:
left.addEventListener('click',function(){ if(num == 0){ num = pic.children.length-1; pic.style.left = -num*boxWidth+'px'; } num--; animate(pic,-num*boxWidth); circle--; if(circle <0){ circle = lis.children.length-1; } for(var i =0;i<lis.children.length;i++){ lis.children[i].className = ''; } lis.children[circle].className = 'selected'; })
實(shí)現(xiàn)效果為:
8、自動(dòng)播放功能
其實(shí)添加一個(gè)定時(shí)器自動(dòng)播放輪播圖,就類似于點(diǎn)擊了右側(cè)按鈕,此時(shí)我們使用手動(dòng)調(diào)用右側(cè)按鈕點(diǎn)擊事件 right.click(),
鼠標(biāo)經(jīng)過(guò)圖片就停止定時(shí)器 ,鼠標(biāo)離開(kāi)圖片就開(kāi)啟定時(shí)器。
var timer = this.setInterval(function(){ right.click(); },2000)
實(shí)現(xiàn)效果為:
完整index.js的代碼為:
window.addEventListener('load',function(){ var left = document.querySelector('.left'); var right = document.querySelector('.right'); var box = document.querySelector('.box'); box.addEventListener('mouseenter',function(){ left.style.display = 'block'; right.style.display = 'block'; }) box.addEventListener('mouseleave',function(){ left.style.display = 'none'; right.style.display = 'none'; }) var pic = document.querySelector('.pic'); var lis = document.querySelector('.lis'); var boxWidth = box.offsetWidth; for(var i = 0;i<pic.children.length;i++){ var li = document.createElement('li'); lis.appendChild(li); //設(shè)置索引號(hào) li.setAttribute('index',i); li.addEventListener('click',function(){ //獲得索引號(hào) var index = this.getAttribute('index'); num = index; circle = index; for(var i = 0;i<lis.children.length;i++){ lis.children[i].className = ''; } this.className = 'selected'; animate(pic,-index*boxWidth) }) } lis.children[0].className = 'selected'; //克隆第一個(gè)li var first = pic.children[0].cloneNode(true); pic.appendChild(first); var num = 0; var circle = 0; //右側(cè)按鈕的功能 right.addEventListener('click',function(){ if(num == pic.children.length-1){ pic.style.left = 0; num = 0; } num++; animate(pic,-num*boxWidth); circle++; if(circle == lis.children.length){ circle = 0; } for(var i =0;i<lis.children.length;i++){ lis.children[i].className = ''; } lis.children[circle].className = 'selected'; }) //左側(cè)按鈕功能 left.addEventListener('click',function(){ if(num == 0){ num = pic.children.length-1; pic.style.left = -num*boxWidth+'px'; } num--; animate(pic,-num*boxWidth); circle--; if(circle <0){ circle = lis.children.length-1; } for(var i =0;i<lis.children.length;i++){ lis.children[i].className = ''; } lis.children[circle].className = 'selected'; }) var timer = this.setInterval(function(){ right.click(); },2000) })
到此這篇關(guān)于JavaScript超詳細(xì)實(shí)現(xiàn)網(wǎng)頁(yè)輪播圖的文章就介紹到這了,更多相關(guān)JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)輪播圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript實(shí)現(xiàn)的動(dòng)態(tài)文字變換
javascript實(shí)現(xiàn)的動(dòng)態(tài)文字變換...2007-07-07JavaScript 事件流、事件處理程序及事件對(duì)象總結(jié)
JS與HTML之間的交互通過(guò)事件實(shí)現(xiàn)。事件就是文檔或?yàn)g覽器窗口中發(fā)生的一些特定的交互瞬間??梢允褂帽O(jiān)聽(tīng)器(或處理程序)來(lái)預(yù)定事件,以便事件發(fā)生時(shí)執(zhí)行相應(yīng)的代碼。本文將介紹JS事件相關(guān)的基礎(chǔ)知識(shí)。2017-04-04javascript用戶注冊(cè)提示效果的簡(jiǎn)單實(shí)例
這個(gè)可以增加用戶驗(yàn)證,不用js alert來(lái)作提示,而是在右邊提示,現(xiàn)在很多網(wǎng)站都這樣做,有需要的朋友可以參考一下2013-08-08微信小程序返回到頂部功能的簡(jiǎn)單實(shí)現(xiàn)
在做微信小程序開(kāi)發(fā)時(shí),遇到一個(gè)問(wèn)題,要如何實(shí)現(xiàn)返回頂部的功能,下面這篇文章主要給大家介紹了微信小程序返回到頂部功能的簡(jiǎn)單實(shí)現(xiàn),文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11js與css實(shí)現(xiàn)彈出層覆蓋整個(gè)頁(yè)面的方法
這篇文章主要介紹了js與css實(shí)現(xiàn)彈出層覆蓋整個(gè)頁(yè)面的方法,分別以實(shí)例形式展示了彈出層覆蓋整個(gè)頁(yè)面的css樣式與js控制的實(shí)現(xiàn)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12ECharts?formatter屬性設(shè)置的3種方法(字符串模板,函數(shù)模板,回調(diào)函數(shù))
formatter有兩種寫(xiě)法,一種字符串模板,另一種是回調(diào)函數(shù),下面這篇文章主要給大家介紹了關(guān)于ECharts?formatter屬性設(shè)置的3種方法,分別是字符串模板,函數(shù)模板,回調(diào)函數(shù),需要的朋友可以參考下2023-02-02學(xué)習(xí)JavaScript圖片預(yù)加載模塊
這篇文章主要介紹了js實(shí)現(xiàn)圖片預(yù)加載的方法,內(nèi)容很詳細(xì),帶領(lǐng)大家全面認(rèn)識(shí)js圖片預(yù)加載模塊,感興趣的小伙伴們可以參考一下2016-11-11詳解小程序原生使用ES7 async/await語(yǔ)法
這篇文章主要介紹了詳解小程序原生使用ES7 async/await語(yǔ)法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08