jQuery手動點擊實現(xiàn)圖片輪播特效
本文寫了一個輪播圖練練手,先寫了一個手動點擊輪播的輪播圖,隨后我會慢慢接著深入寫自動輪播圖和鼠標(biāo)懸浮圖片停止移動輪播圖等。
下面來看看最終做的手動點擊輪播效果:
一、原理說明
(1)首先是輪播圖的架構(gòu),我采用了一個最外邊的大div包住兩個小div,一個小div里面放四張圖片,另一個小div里面放四個數(shù)字按鈕
(2)對最外邊的大div設(shè)置的寬度為圖片的寬度,超出大div寬度的都需要隱藏,但是對于盛放圖片的小div設(shè)置寬度為2000px,大一點方便四張圖左浮動布局
(3)當(dāng)數(shù)字按鈕點擊時,獲取按鈕的索引值,這樣就可以知道每張圖片左移多少寬度
從上面的圖可以看出,四張圖片是浮動起來橫著的布局,當(dāng)數(shù)字按鈕被點擊時,圖片就要按照數(shù)字按鈕的索引值引動N個圖片的寬度到達父框架里面展示,因為父框架外面的圖片都會被隱藏掉~~~~~如果你還看不懂原理的話,我只能吐血了~~~~
二、下面來看主體程序
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>輪播圖①(手動點擊輪播)</title> <link type="text/css" rel="stylesheet" href="css/layout.css" /> </head> <body> <div class="slideShow"> <!--圖片布局開始--> <ul> <li><a href="#"><img src="img/picture01.jpg" /></a></li> <li><a href="#"><img src="img/picture02.jpg" /></a></li> <li><a href="#"><img src="img/picture03.jpg" /></a></li> <li><a href="#"><img src="img/picture04.jpg" /></a></li> </ul> <!--圖片布局結(jié)束--> <!--按鈕布局開始--> <div class="showNav"> <span class="active">1</span> <span>2</span> <span>3</span> <span>4</span> </div> <!--按鈕布局結(jié)束--> </div> <script src="js/jquery-1.11.3.js"></script> <script src="js/layout.js"></script> </body> </html>
上面布局我已經(jīng)在原理中說明了,感興趣的自己看原理~~~~
三、CSS樣式
*{ margin: 0; padding: 0; } ul{ list-style: none; } .slideShow{ width: 346px; height: 210px; /*其實就是圖片的高度*/ border: 1px #eeeeee solid; margin: 100px auto; position: relative; overflow: hidden; /*此處需要將溢出框架的圖片部分隱藏*/ } .slideShow ul{ width: 2000px; position: relative; /*此處需注意relative : 對象不可層疊,但將依據(jù)left,right,top,bottom等屬性在正常文檔流中偏移位置,如果沒有這個屬性,圖片將不可左右移動*/ } .slideShow ul li{ float: left; /*讓四張圖片左浮動,形成并排的橫著布局,方便點擊按鈕時的左移動*/ width: 346px; } .slideShow .showNav{ /*用絕對定位給數(shù)字按鈕進行布局*/ position: absolute; right: 10px; bottom: 5px; text-align:center; font-size: 12px; line-height: 20px; } .slideShow .showNav span{ cursor: pointer; display: block; float: left; width: 20px; height: 20px; background: #ff5a28; margin-left: 2px; color: #fff; } .slideShow .showNav .active{ background: #b63e1a; }
上面樣式我已經(jīng)備注出來很重要的地方了,相信有基礎(chǔ)的很容易看懂,剛開始我在.slideShow ul樣式里面忘了寫position: relative;導(dǎo)致后面的jquery程序圖片一直無法移動,耽誤了很長時間才找出這個錯誤,希望大家可以注意這個地方~~~~~~~
四、jQuery程序
$(document).ready(function(){ var slideShow=$(".slideShow"), //獲取最外層框架的名稱 ul=slideShow.find("ul"), showNumber=slideShow.find(".showNav span"),//獲取按鈕 oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個圖片的寬度 showNumber.on("click",function(){ //為每個按鈕綁定一個點擊事件 $(this).addClass("active").siblings().removeClass("active"); //按鈕被點擊時為這個按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉 var index=$(this).index(); //獲取哪個按鈕被點擊,也就是找到被點擊按鈕的索引值 ul.animate({ "left":-oneWidth*index, //注意此處用到left屬性,所以ul的樣式里面需要設(shè)置position: relative; 讓ul左移N個圖片大小的寬度,N根據(jù)被點擊的按鈕索引值index確定 }) }) })
是不是覺得很簡單,也是幾句話就搞定了手動點擊的輪播效果,上面程序需要注意的是left屬性是左移動,所以為負(fù)值~~~~~~~
精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
下次文章就為大家分享自動輪播特效,希望大家不要錯過。
相關(guān)文章
jQuery on()方法示例及jquery on()方法的優(yōu)點
使用jquery on()方法綁定事件是官方推薦的一種方法,接下來跟著小編來學(xué)習(xí)jquery on()方法,小伙伴快來一起學(xué)習(xí)吧2015-08-08Jquery ajax請求導(dǎo)出Excel表格的實現(xiàn)代碼
下面小編就為大家?guī)硪黄狫query ajax請求導(dǎo)出Excel表格的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06jquery預(yù)覽圖片實現(xiàn)鼠標(biāo)放上去顯示實際大小
本文為大家介紹的這個示例為jquery實現(xiàn)的預(yù)覽圖片,當(dāng)鼠標(biāo)放上去顯示實際大小,感興趣的朋友可以學(xué)習(xí)下2014-01-01jQuery實現(xiàn)按鈕點擊遮罩加載及處理完后恢復(fù)的效果
這篇文章主要介紹了jQuery實現(xiàn)按鈕點擊遮罩加載及處理完后恢復(fù)的效果,涉及jQuery與asp.net后臺交互實現(xiàn)頁面效果動態(tài)變換的相關(guān)技巧,需要的朋友可以參考下2016-06-06jQuery實現(xiàn)鼠標(biāo)拖拽登錄框移動效果
這篇文章主要為大家詳細(xì)介紹了jQuery實現(xiàn)鼠標(biāo)拖拽登錄框移動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09Jquery實現(xiàn)多個表格的全選復(fù)選框功能方式
這篇文章主要介紹了Jquery實現(xiàn)多個表格的全選復(fù)選框功能方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12