jQuery實現(xiàn)輪播圖效果demo
本文實例為大家分享了jQuery實現(xiàn)輪播圖效果的具體代碼,供大家參考,具體內(nèi)容如下
效果展示:

編程思路:
1. 首先是基礎(chǔ)的布局,使用"子絕父相"等頁面布局方法,將圖片、左右按鈕以及每張圖片下方對應(yīng)的標識小按鈕安排的明明白白。
2. JS中在通過點擊左右按鈕來切換圖片時,使用三個變量分別來表示當前顯示的圖片序號、點擊上一張按鈕時候顯示的圖片序號、點擊下一張按鈕時候顯示的圖片序號。
3. 在自動輪播的時候,通過使用定時器來改變當前顯示的圖片序號來控制輪播
具體代碼:
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; //點擊上一張按鈕時候的一個標志位
var next_mark=0; //點擊下一張按鈕時候的一個標志位
var cur_pic=$('.slide_pic').length-1; //當前圖片的序號
$('.prev_one').click(function(){
prev_mark=cur_pic; //獲取當前圖片的序號
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');
});
// 輪播圖下面的指示點
$.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');
});
});
// 鼠標移入圖片則停止輪播;鼠標移出圖片則開始輪播
var slide_timer=setInterval(auto_slide,2000);
$('#slideShow').mouseenter(function(){
clearInterval(slide_timer);
});
$('#slideShow').mouseleave(function(){
slide_timer=setInterval(auto_slide,2000);
});
// 自動輪播函數(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)于輪播圖效果的專題,請點擊下方鏈接查看學習
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery contains過濾器實現(xiàn)精確匹配使用方法
contains 選擇器選取包含指定字符串的元素。該字符串可以是直接包含在元素中的文本,或者被包含于子元素中。經(jīng)常與其他元素/選擇器一起使用,來選擇指定的組中包含指定文本的元素2013-04-04
jQuery使用attr()方法同時設(shè)置多個屬性值用法實例
這篇文章主要介紹了jQuery使用attr()方法同時設(shè)置多個屬性值的用法,實例分析了jQuery中attr方法實現(xiàn)多個屬性設(shè)置的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03
淺析jQuery(function(){})與(function(){})(jQuery)之間的區(qū)別
本篇文章主要是對jQuery(function(){})與(function(){})(jQuery)之間的區(qū)別進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01
jQuery ajax 當async為false時解決同步操作失敗的問題
這篇文章主要介紹了 jQuery ajax 當async為false時解決同步操作失敗的問題的相關(guān)資料,需要的朋友可以參考下2016-11-11
Jquery 類網(wǎng)頁微信二維碼圖塊滾動效果具體實現(xiàn)
網(wǎng)頁微信二維碼圖塊滾動效果想必大家都有見到過吧,在接下來的文章中將為大家詳細介紹下使用Jquery是如何實現(xiàn),感興趣的朋友可以參考下2013-10-10

