用JS實(shí)現(xiàn)輪播圖效果(二)
來源:易賢網(wǎng) 閱讀:797 次 日期:2016-07-12 15:09:16
溫馨提示:易賢網(wǎng)小編為您整理了“用JS實(shí)現(xiàn)輪播圖效果(二)”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了用JS實(shí)現(xiàn)輪播圖效果(二)的相關(guān)資料,需要的朋友可以參考下

js代碼如下:

window.onload = function(){

//輪播初始化

var lunbo = document.getElementById('content');

var imgs = lunbo.getElementsByTagName('img');

var uls = lunbo.getElementsByTagName('ul');

var lis = lunbo.getElementsByTagName('li');

var next = document.getElementById('next');

var prev = document.getElementById('prev');

var item = 0;

//初始狀態(tài)下,一個(gè)圓圈為高亮模式

lis[0].style.fontSize = '26px';

lis[0].style.color = '#fff';

imgs[0].style.display = 'block';

//定義一個(gè)全局變量,用來進(jìn)行自動(dòng)輪播圖片順序的變化

var pic_index = 1;

//自動(dòng)輪播.使用pic_time記錄播放,可以隨時(shí)使用clearInterval()清除掉。

var pic_time = setInterval(autobofang,1000);

//自動(dòng)播放的事件處理

function autobofang(){

if(pic_index >= lis.length){

pic_index = 0;

}

picChange(pic_index);

pic_index++;

}

//手動(dòng)輪播

for(var i=0;i<lis.length;i++){

lis[i].addEventListener("mouseover",change,false);

}

function change(event){

var event=event||window.event;

var target=event.target||event.srcElement;

var children = target.parentNode.children;

for(var i=0;i<children.length;i++){

if(target == children[i]){

picChange(i);

}

}

}

//圖片切換函數(shù)

function picChange(i){

//讓所有圖片都不顯示,所有圓圈都為普通樣式

for(var j=0;j<imgs.length;j++){

imgs[j].style.display = 'none';

lis[j].style.fontSize = '24px';

lis[j].style.color = '#999';

}

//讓選中的索引的圖片顯示,對(duì)應(yīng)的圓圈高亮

imgs[i].style.display = 'block';

lis[i].style.fontSize = '26px';

lis[i].style.color = '#fff';

}

//當(dāng)鼠標(biāo)移近圖片區(qū)域內(nèi),自動(dòng)播放停止

lunbo.addEventListener("mouseover",function(){

clearInterval(pic_time);

},false);

//當(dāng)鼠標(biāo)移出圖片區(qū)域內(nèi),自動(dòng)播放繼續(xù)

lunbo.addEventListener("mouseout",function(){pic_time = setInterval(autobofang,1000); },false);

//后退箭頭點(diǎn)擊事件,圖片會(huì)跟著點(diǎn)擊事件不斷變化

next.addEventListener("click",movenext,false);

function movenext(){

if(item == 2){

item=0;

}

else{

item+=1;

}

picChange(item);

}

prev.addEventListener("click",moveprev,false);

function moveprev(){

if(item == 0){

item=2;

}

else{

item-=1;

}

picChange(item);

}

}

總結(jié):

基本輪播效果已經(jīng)實(shí)現(xiàn),后期需要做的事:是對(duì)代碼要進(jìn)行精簡,封裝,提高運(yùn)行效率。

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:用JS實(shí)現(xiàn)輪播圖效果(二)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)