JavaScript實現(xiàn)六種網(wǎng)頁圖片輪播效果詳解
在網(wǎng)頁中,我們經(jīng)常會看到各種輪播圖的效果,它們到底是怎樣實現(xiàn)的呢?今天,我們就一起來看一下!首先,我們需要準備若干張圖片,在這里我準備了五張圖片。
功能需求:
鼠標經(jīng)過輪播圖模塊,左右按鈕顯示,離開隱藏左右按鈕。
點擊右側按鈕一次,圖片往左播放一張,以此類推, 左側按鈕同理。
圖片播放的同時,下面小圓圈模塊跟隨一起變化。
點擊小圓圈,可以播放相應圖片。
鼠標不經(jīng)過輪播圖, 輪播圖也會自動播放圖片。
鼠標經(jīng)過,輪播圖模塊, 自動播放停止。
我們頁面布局如下所示:

接下來就一步步的實現(xiàn)功能
先創(chuàng)建HTML頁面
實現(xiàn)流程是:先給定一個大盒子,為了方便后面盒子的定位操作,再給它一個相對定位,把圖片通過無序列表的形式添加進大盒子中,因為我們要實現(xiàn)的輪播圖效果是橫向的,所以我們可以給圖片添加float:left屬性,又因為圖片所在的ul不夠大,所以其他的圖片會被擠到下面,所以我們可以手動修改圖片所在的ul的大?。唤酉聛韺懸粋€無序列表用于放置小圓圈,通過絕對定位的方式將其定位到大盒子的下面,在將小圓圈加進去,方便我們實現(xiàn)點擊對應的小圓圈,就跳轉到相應圖片的效果。然后將左右箭頭通過絕對定位分別定到大盒子兩側合適位置。最后,我們再將大盒子外面的內(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;
}
此時頁面效果為:

再實現(xiàn)js部分的功能。
1、當鼠標經(jīng)過輪播圖模塊,左右按鈕顯示,離開隱藏左右按鈕。
首先,我們先通過display:none讓我們初始的兩個箭頭隱藏;然后獲取兩個箭頭和大盒子,在給大盒子添加鼠標經(jīng)過和鼠標離開事件。如下所示:
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';
})
實現(xiàn)效果為:

2、動態(tài)生成小圓圈
先刪除掉所有的小圓圈的li,如圖所示:

因為我們創(chuàng)建的小圓圈是根據(jù)圖片的張數(shù)決定的,所以我們的核心思路就是:小圓圈的個數(shù)要跟圖片張數(shù)一致,先得到ul里面圖片的張數(shù)(圖片放入li里面,所以就是li的個數(shù)),然后利用循環(huán)動態(tài)通過創(chuàng)建節(jié)點createElement(‘li')和插入節(jié)點 ul. appendChild(li)生成小圓圈(這個小圓圈要放入ul里面)要注意第一個小圓圈需要添加selected類。
實現(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';
實現(xiàn)效果為:

3、點擊小圓圈,小圓圈變色
在生成小li的同時,根據(jù)排他思想,給小圓圈添加點擊事件,當點擊對應的小圓圈時,讓其添加selected類,其余的小圓圈刪除selected類。
代碼為:
li.addEventListener('click',function(){
for(var i =0;i<lis.children.length;i++){
lis.childern[i].className = '';
}
this.className = 'selected';
})
實現(xiàn)效果為:

4、點擊小圓圈滾動圖片
這里就用到動畫函數(shù),前面已經(jīng)講過怎樣封裝動畫函數(shù),這里不在贅述,直接引用。但是要注意將動畫函數(shù)的js文件放在我們index.js的上面。又因為只有添加了定位了元素才可以使用動畫函數(shù),我們還需要給pic這個ul添加定位。然后根據(jù)規(guī)律發(fā)現(xiàn): 點擊某個小圓圈 ,ul滾動的距離為: 小圓圈的索引號乘以圖片的寬度。(因為圖片是向左走,所以為負值)所以需要知道小圓圈的索引號, 我們就可以在生成小圓圈的時候,給它設置一個自定義屬性,點擊的時候獲取這個自定義屬性。
先在生成li的時候設置索引:
li.setAttribute('index',i);
然后在給li添加點擊事件的時候獲得索引,并得到圖片寬度,調(diào)用動畫函數(shù):
li.addEventListener('click',function(){
var boxWidth = box.offsetWidth;
//獲得索引號
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)
})
實現(xiàn)效果為:

5、點擊右側按鈕一次,就讓圖片滾動一張。
可以直接給右側按鈕添加點擊事件,聲明一個變量num, 點擊一次,自增1, 讓這個變量乘以圖片寬度,就是 ul 的滾動距離。
var num = 0;
right.addEventListener('click',function(){
num++;
animate(pic,-num*boxWidth);
})
實現(xiàn)效果為:

我們發(fā)現(xiàn),當點擊右側按鈕時,可以實現(xiàn)圖片的切換效果,但是當點擊到最后一張圖片的時候,就會停留在顯頁面初始背景,并不美觀,所以我們就可以通過圖片無縫滾動原理讓圖片無縫滾動,操作方法為。將.pic列表里的第一個li通過cloneNode(true)添加一份,然后通過appendChild()復制到該列表的末尾,然后再在js頁面中給num添加一個判斷條件,即當num的值等于這個列表里面元素的個數(shù)-1的時候,讓ul移動的距離變?yōu)?,并讓num等于0。
代碼為:
var first = pic.children[0].cloneNode(true);
pic.appendChild(first);
//右側按鈕的功能
var num = 0;
right.addEventListener('click',function(){
if(num == pic.children.length-1){
pic.style.left = 0;
num = 0;
}
num++;
animate(pic,-num*boxWidth);
})
實現(xiàn)效果為:

成功實現(xiàn)。
6、點擊右側按鈕, 小圓圈跟隨變化
需要進行的操作是:再聲明一個變量circle,每次點擊右側按鈕時自增1,因為當我們左側按鈕點擊時也會實現(xiàn)該效果,也需要這個變量,因此要聲明全局變量。但是圖片有5張,我們小圓圈只有4個少一個,必須加一個判斷條件,如果circle == 4就 從新復原為 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';
})
運行結果為:

但是這樣還是有點小問題的,當我們讓小圓圈和右側按鈕結合起來使用的時候,就會發(fā)現(xiàn)錯誤,如下:

當我們點擊小圓點時,也可以跳轉到相應的圖片頁,但當我們繼續(xù)點擊右側按鈕時,就會發(fā)現(xiàn)下面的小圓點和對應的圖片不對應了。這是我們我們的右側按鈕點擊事件時通過變量num來控制的,而num變量和小圓圈的點擊事件沒有任何關系,所以就存在差異。
我們的解決方案就是每次點擊小li時,獲得它的索引號,然后把num和circle的值改為得到的索引號的值,代碼為:
var index = this.getAttribute('index');
num = index;
circle = index;
實現(xiàn)效果為:

7、左側按鈕功能制作
和右側按鈕做法類似,不在贅述,代碼如下:
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';
})
實現(xiàn)效果為:

8、自動播放功能
其實添加一個定時器自動播放輪播圖,就類似于點擊了右側按鈕,此時我們使用手動調(diào)用右側按鈕點擊事件 right.click(),鼠標經(jīng)過圖片就停止定時器 ,鼠標離開圖片就開啟定時器。
var timer = this.setInterval(function(){
right.click();
},2000)
實現(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);
//設置索引號
li.setAttribute('index',i);
li.addEventListener('click',function(){
//獲得索引號
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';
//克隆第一個li
var first = pic.children[0].cloneNode(true);
pic.appendChild(first);
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';
})
//左側按鈕功能
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)
})
至此,我們輪播圖的全部功能都實現(xiàn)了,你學會了嗎??
以上就是JavaScript實現(xiàn)六種網(wǎng)頁圖片輪播效果詳解的詳細內(nèi)容,更多關于JavaScript網(wǎng)頁圖片輪播的資料請關注腳本之家其它相關文章!
相關文章
使用ionic(選項卡欄tab) icon(圖標) ionic上拉菜單(ActionSheet) 實現(xiàn)通訊錄界面切換實例
這篇文章主要介紹了使用ionic(選項卡欄tab) icon(圖標) ionic上拉菜單(ActionSheet) 實現(xiàn)通訊錄界面切換實例代碼,需要的朋友可以參考下2017-10-10
BootStrap select2 動態(tài)改變值的方法
這篇文章主要介紹了BootStrap select2 動態(tài)改變值的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
JavaScript SHA1加密算法實現(xiàn)詳細代碼
這篇文章主要為大家詳細介紹了JavaScript SHA1加密算法實現(xiàn)代碼,具有一定的參考價值,感興趣的朋友可以參考一下2016-10-10
Webpack實現(xiàn)按需打包Lodash的幾種方法詳解
這篇文章主要給大家介紹了關于Webpack實現(xiàn)按需打包Lodash的幾種方法,文中介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-05-05

