jQuery手動(dòng)點(diǎn)擊實(shí)現(xiàn)圖片輪播特效
本文寫了一個(gè)輪播圖練練手,先寫了一個(gè)手動(dòng)點(diǎn)擊輪播的輪播圖,隨后我會慢慢接著深入寫自動(dòng)輪播圖和鼠標(biāo)懸浮圖片停止移動(dòng)輪播圖等。
下面來看看最終做的手動(dòng)點(diǎn)擊輪播效果:

一、原理說明
(1)首先是輪播圖的架構(gòu),我采用了一個(gè)最外邊的大div包住兩個(gè)小div,一個(gè)小div里面放四張圖片,另一個(gè)小div里面放四個(gè)數(shù)字按鈕
(2)對最外邊的大div設(shè)置的寬度為圖片的寬度,超出大div寬度的都需要隱藏,但是對于盛放圖片的小div設(shè)置寬度為2000px,大一點(diǎn)方便四張圖左浮動(dòng)布局
(3)當(dāng)數(shù)字按鈕點(diǎn)擊時(shí),獲取按鈕的索引值,這樣就可以知道每張圖片左移多少寬度

從上面的圖可以看出,四張圖片是浮動(dòng)起來橫著的布局,當(dāng)數(shù)字按鈕被點(diǎn)擊時(shí),圖片就要按照數(shù)字按鈕的索引值引動(dòng)N個(gè)圖片的寬度到達(dá)父框架里面展示,因?yàn)楦缚蚣芡饷娴膱D片都會被隱藏掉~~~~~如果你還看不懂原理的話,我只能吐血了~~~~
二、下面來看主體程序
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>輪播圖①(手動(dòng)點(diǎn)擊輪播)</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; /*其實(shí)就是圖片的高度*/
border: 1px #eeeeee solid;
margin: 100px auto;
position: relative;
overflow: hidden; /*此處需要將溢出框架的圖片部分隱藏*/
}
.slideShow ul{
width: 2000px;
position: relative; /*此處需注意relative : 對象不可層疊,但將依據(jù)left,right,top,bottom等屬性在正常文檔流中偏移位置,如果沒有這個(gè)屬性,圖片將不可左右移動(dòng)*/
}
.slideShow ul li{
float: left; /*讓四張圖片左浮動(dòng),形成并排的橫著布局,方便點(diǎn)擊按鈕時(shí)的左移動(dòng)*/
width: 346px;
}
.slideShow .showNav{ /*用絕對定位給數(shù)字按鈕進(jìn)行布局*/
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程序圖片一直無法移動(dòng),耽誤了很長時(shí)間才找出這個(gè)錯(cuò)誤,希望大家可以注意這個(gè)地方~~~~~~~
四、jQuery程序
$(document).ready(function(){
var slideShow=$(".slideShow"), //獲取最外層框架的名稱
ul=slideShow.find("ul"),
showNumber=slideShow.find(".showNav span"),//獲取按鈕
oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個(gè)圖片的寬度
showNumber.on("click",function(){ //為每個(gè)按鈕綁定一個(gè)點(diǎn)擊事件
$(this).addClass("active").siblings().removeClass("active"); //按鈕被點(diǎn)擊時(shí)為這個(gè)按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉
var index=$(this).index(); //獲取哪個(gè)按鈕被點(diǎn)擊,也就是找到被點(diǎn)擊按鈕的索引值
ul.animate({
"left":-oneWidth*index, //注意此處用到left屬性,所以ul的樣式里面需要設(shè)置position: relative; 讓ul左移N個(gè)圖片大小的寬度,N根據(jù)被點(diǎn)擊的按鈕索引值index確定
})
})
})
是不是覺得很簡單,也是幾句話就搞定了手動(dòng)點(diǎn)擊的輪播效果,上面程序需要注意的是left屬性是左移動(dòng),所以為負(fù)值~~~~~~~
精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播
下次文章就為大家分享自動(dòng)輪播特效,希望大家不要錯(cuò)過。
- 12款經(jīng)典的白富美型—jquery圖片輪播插件—前端開發(fā)必備
- Jquery代碼實(shí)現(xiàn)圖片輪播效果(一)
- 原生js和jquery實(shí)現(xiàn)圖片輪播特效
- jQuery圖片輪播的具體實(shí)現(xiàn)
- 基于JQuery的實(shí)現(xiàn)圖片輪播效果(焦點(diǎn)圖)
- 原生js和jquery實(shí)現(xiàn)圖片輪播淡入淡出效果
- 基于jQuery實(shí)現(xiàn)左右圖片輪播(原理通用)
- 基于jquery的圖片輪播 tab切換組件
- jQuery左右滾動(dòng)支持圖片放大縮略圖圖片輪播代碼分享
- 使用jQuery實(shí)現(xiàn)圖片輪播效果
相關(guān)文章
使用jQuery內(nèi)容過濾選擇器選擇元素實(shí)例講解
內(nèi)容過濾選擇器:根據(jù)元素中的文字內(nèi)容或所包含的子元素特征獲取元素,其文字內(nèi)容可以模糊或絕對匹配進(jìn)行元素定位,接下來為大家詳細(xì)介紹下jQuery選擇器,感興趣的朋友可以參考下哈2013-04-04
jquery 實(shí)現(xiàn)表單驗(yàn)證功能代碼(簡潔)
jquery 實(shí)現(xiàn)表單驗(yàn)證功能代碼,代碼比較簡潔,需要的朋友可以參考下2012-07-07
jQuery使用$.get()方法從服務(wù)器文件載入數(shù)據(jù)實(shí)例
這篇文章主要介紹了jQuery使用$.get()方法從服務(wù)器文件載入數(shù)據(jù),較為簡單的分析了jQuery中g(shù)et方法的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
通過jQuery源碼學(xué)習(xí)javascript(三)
承接上兩篇繼續(xù)寫下去。我盡量把我明白的地方給大家說清楚。有些大家的提問我也有點(diǎn)搞不明白,如果有人能解答,再好不過了2012-12-12
jquery load()在firefox(火狐)下顯示不正常的解決方法
覺得應(yīng)該是由于 直接將www.baidu.com的內(nèi)容放到div中,對于較嚴(yán)格的FireFox可能不會處理用cssviewter查看處理后的頁面源碼果然發(fā)現(xiàn)div中為空2011-04-04
JQuery的AJAX實(shí)現(xiàn)文件下載的小例子
JQuery的ajax函數(shù)的返回類型只有xml、text、json、html等類型,沒有“流”類型,所以我們要實(shí)現(xiàn)ajax下載,不能夠使用相應(yīng)的ajax函數(shù)進(jìn)行文件下載。但可以用js生成一個(gè)form,用這個(gè)form提交參數(shù),并返回“流”類型的數(shù)據(jù)。在實(shí)現(xiàn)過程中,頁面也沒有進(jìn)行刷新2013-05-05

