寫了一個輪播圖練練手,先寫了一個手動點擊輪播的輪播圖,隨後我會慢慢接着深刻寫自動輪播圖和鼠標懸浮圖片中止移動輪播圖等,雖然今天我生日,可是代碼仍是得寫的,不能找藉口放鬆本身,原地踏步也算後退.css
下面來看看最終作的手動點擊輪播效果:html
1、原理說明jquery
(1)首先是輪播圖的架構,我採用了一個最外邊的大div包住兩個小div,一個小div裏面放四張圖片,另外一個小div裏面放四個數字按鈕架構
(2)對最外邊的大div設置的寬度爲圖片的寬度,超出大div寬度的都須要隱藏,可是對於盛放圖片的小div設置寬度爲2000px,大一點方便四張圖左浮動佈局框架
(3)當數字按鈕點擊時,獲取按鈕的索引值,這樣就能夠知道每張圖片左移多少寬度ide
好吧,我以爲純文字說明有點淡淡的憂傷,估計大家也很差理解,我閒的無聊就作了一張搞笑的原理說明圖,我要放大招了~~~~佈局
從上面的圖能夠看出,四張圖片是浮動起來橫着的佈局,當數字按鈕被點擊時,圖片就要按照數字按鈕的索引值引動N個圖片的寬度到達父框架裏面展現,由於父框架外面的圖片都會被隱藏掉,若是你還看不懂原理的話,我只能吐血了.this
2、下面來看主體程序spa
<!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> <!--圖片佈局結束--> <!--按鈕佈局開始--> <div class="showNav"> <span class="active">1</span> <span>2</span> <span>3</span> <span>4</span> </div> <!--按鈕佈局結束--> </div> <script src="js/jquery-1.11.3.js"></script> <script src="js/layout.js"></script> </body> </html>
上面佈局我已經在原理中說明了,感興趣的本身看原理.code
3、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 : 對象不可層疊,但將依據left,right,top,bottom等屬性在正常文檔流中偏移位置,若是沒有這個屬性,圖片將不可左右移動*/
}
.slideShow ul li{
float: left; /*讓四張圖片左浮動,造成並排的橫着佈局,方便點擊按鈕時的左移動*/
width: 346px;
}
.slideShow .showNav{ /*用絕對定位給數字按鈕進行佈局*/
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;
}
上面樣式我已經備註出來很重要的地方了,相信有基礎的很容易看懂,剛開始我在.slideShow ul樣式裏面忘了寫position: relative;致使後面的jquery程序圖片一直沒法移動,耽誤了很長時間才找出這個錯誤,但願你們能夠注意這個地方.
4、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"); //按鈕被點擊時爲這個按鈕添加高亮狀態,而且將其餘按鈕高亮狀態去掉
var index=$(this).index(); //獲取哪一個按鈕被點擊,也就是找到被點擊按鈕的索引值
ul.animate({
"left":-oneWidth*index, //注意此處用到left屬性,因此ul的樣式裏面須要設置position: relative; 讓ul左移N個圖片大小的寬度,N根據被點擊的按鈕索引值index肯定
})
})
})
額,是否是以爲很簡單,也是幾句話就搞定了手動點擊的輪播效果,上面程序須要注意的是left屬性是左移動,因此爲負值.
寫到這裏我是真的黔驢技窮了,若是你再看不懂的話,我建議你去看看網頁的基礎佈局以及JQuery的知識,本人才疏學淺只能寫成這樣了,方便之後剛入行像我同樣的學弟學妹看看吧,明天繼續深刻寫自動輪播圖.