jQuery實(shí)現(xiàn)輪播圖效果demo
本文實(shí)例為大家分享了jQuery實(shí)現(xiàn)輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下
效果展示:
編程思路:
1. 首先是基礎(chǔ)的布局,使用"子絕父相"等頁(yè)面布局方法,將圖片、左右按鈕以及每張圖片下方對(duì)應(yīng)的標(biāo)識(shí)小按鈕安排的明明白白。
2. JS中在通過(guò)點(diǎn)擊左右按鈕來(lái)切換圖片時(shí),使用三個(gè)變量分別來(lái)表示當(dāng)前顯示的圖片序號(hào)、點(diǎn)擊上一張按鈕時(shí)候顯示的圖片序號(hào)、點(diǎn)擊下一張按鈕時(shí)候顯示的圖片序號(hào)。
3. 在自動(dòng)輪播的時(shí)候,通過(guò)使用定時(shí)器來(lái)改變當(dāng)前顯示的圖片序號(hào)來(lái)控制輪播
具體代碼:
HTML代碼:
<div id="slideShow"> <a href="#" class="slide_pic"><img src="../img/phone_photo/p1.jpg" alt="0"></a> <a href="#" class="slide_pic"><img src="../img/phone_photo/p2.jpg" alt="1"></a> <a href="#" class="slide_pic"><img src="../img/phone_photo/p3.jpg" alt="2"></a> <a href="#" class="slide_pic"><img src="../img/phone_photo/p4.jpg" alt="3"></a> <a href="#" class="slide_pic"><img src="../img/phone_photo/p5.jpg" alt="4"></a> <a href="#" class="slide_pic"><img src="../img/phone_photo/p6.jpg" alft="5"></a> <button class="prev_one"> < </button> <button class="next_one"> > </button> <ul id="mark_box"> <li class="mark">1</li> <li class="mark">2</li> <li class="mark">3</li> <li class="mark">4</li> <li class="mark">5</li> <li class="mark">6</li> </ul> </div>
CSS代碼:
#slideShow{ width: 330px; height: 245px; background-color: #999999; text-align: center; left: 50%; margin-left: -165px; position: relative; } #slideShow .slide_pic{ position: absolute; left: 0; top: 0; } #slideShow .prev_one{ position: absolute; left: 0; top: 45%; } #slideShow .next_one{ position: absolute; right: 0; top: 45%; } #slideShow #mark_box{ position: absolute; bottom: 0; } #mark_box .mark{ width: 20px; height: 20px; border-radius: 20px; padding: 2px; text-align: center; line-height: 20px; background-color: red; float: left; list-style: none; margin: 10px 10px; cursor: pointer; } #mark_box .active_img{ background-color: green; }
Javascript代碼:
$(function(){ var prev_mark=0; //點(diǎn)擊上一張按鈕時(shí)候的一個(gè)標(biāo)志位 var next_mark=0; //點(diǎn)擊下一張按鈕時(shí)候的一個(gè)標(biāo)志位 var cur_pic=$('.slide_pic').length-1; //當(dāng)前圖片的序號(hào) $('.prev_one').click(function(){ prev_mark=cur_pic; //獲取當(dāng)前圖片的序號(hào) if(prev_mark === 0){ prev_mark=$('.slide_pic').length-1; } else{ prev_mark--; } cur_pic=prev_mark; $('.slide_pic').eq(cur_pic).fadeIn(500).siblings('.slide_pic').fadeOut(500); $('.mark').eq(cur_pic).addClass('active_img').siblings('.mark').removeClass('active_img'); }); $('.next_one').click(function(){ next_mark=cur_pic; if(next_mark === $('.slide_pic').length-1){ next_mark=0; } else{ next_mark++; } cur_pic=next_mark; $('.slide_pic').eq(cur_pic).fadeIn(500).siblings('.slide_pic').fadeOut(500); $('.mark').eq(cur_pic).addClass('active_img').siblings('.mark').removeClass('active_img'); }); // 輪播圖下面的指示點(diǎn) $.each($('.mark'),function(index,value){ $(value).click(function(){ cur_pic=this.innerHTML-1; $('.slide_pic').eq(cur_pic).fadeIn(500).siblings('.slide_pic').fadeOut(500); $(this).addClass('active_img').siblings('.mark').removeClass('active_img'); }); }); // 鼠標(biāo)移入圖片則停止輪播;鼠標(biāo)移出圖片則開(kāi)始輪播 var slide_timer=setInterval(auto_slide,2000); $('#slideShow').mouseenter(function(){ clearInterval(slide_timer); }); $('#slideShow').mouseleave(function(){ slide_timer=setInterval(auto_slide,2000); }); // 自動(dòng)輪播函數(shù) function auto_slide(){ if(cur_pic === $('.slide_pic').length-1){ cur_pic =0; } else { cur_pic++; } $('.slide_pic').eq(cur_pic).fadeIn(500).siblings('.slide_pic').fadeOut(500); $('.mark').eq(cur_pic).addClass('active_img').siblings('.mark').removeClass('active_img'); } });
更多關(guān)于輪播圖效果的專(zhuān)題,請(qǐng)點(diǎn)擊下方鏈接查看學(xué)習(xí)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery contains過(guò)濾器實(shí)現(xiàn)精確匹配使用方法
contains 選擇器選取包含指定字符串的元素。該字符串可以是直接包含在元素中的文本,或者被包含于子元素中。經(jīng)常與其他元素/選擇器一起使用,來(lái)選擇指定的組中包含指定文本的元素2013-04-04jQuery使用attr()方法同時(shí)設(shè)置多個(gè)屬性值用法實(shí)例
這篇文章主要介紹了jQuery使用attr()方法同時(shí)設(shè)置多個(gè)屬性值的用法,實(shí)例分析了jQuery中attr方法實(shí)現(xiàn)多個(gè)屬性設(shè)置的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03淺析jQuery(function(){})與(function(){})(jQuery)之間的區(qū)別
本篇文章主要是對(duì)jQuery(function(){})與(function(){})(jQuery)之間的區(qū)別進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-01-01jQuery發(fā)送Ajax請(qǐng)求的幾種方法舉例
Ajax一個(gè)向后端發(fā)送請(qǐng)求的方式,下面這篇文章主要給大家介紹了關(guān)于jQuery發(fā)送Ajax請(qǐng)求的幾種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用jQuery具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-06-06jQuery ajax 當(dāng)async為false時(shí)解決同步操作失敗的問(wèn)題
這篇文章主要介紹了 jQuery ajax 當(dāng)async為false時(shí)解決同步操作失敗的問(wèn)題的相關(guān)資料,需要的朋友可以參考下2016-11-11Jquery 類(lèi)網(wǎng)頁(yè)微信二維碼圖塊滾動(dòng)效果具體實(shí)現(xiàn)
網(wǎng)頁(yè)微信二維碼圖塊滾動(dòng)效果想必大家都有見(jiàn)到過(guò)吧,在接下來(lái)的文章中將為大家詳細(xì)介紹下使用Jquery是如何實(shí)現(xiàn),感興趣的朋友可以參考下2013-10-10