jquery實(shí)現(xiàn)滑動(dòng)圖片自己測(cè)試的例子
更新時(shí)間:2013年11月05日 17:18:24 作者:
最近使用jquery寫了一個(gè)圖片滑動(dòng)的插件,雖然還是有些問(wèn)題存在,用法很簡(jiǎn)單,希望對(duì)大家有所幫助
最近正在回顧之前的一些基礎(chǔ)知識(shí),用jquery寫了一個(gè)圖片滑動(dòng)的插件,雖然還是有些問(wèn)題存在,用法很簡(jiǎn)單,只要在對(duì)目標(biāo)元素綁定slideW()函數(shù)即可,該函數(shù)最多支持兩個(gè)輸入,分別是圖片變化之后的寬度,以及動(dòng)畫的速度,如果不輸入,則采用默認(rèn)的寬度以及默認(rèn)的速度。
下面是我自己測(cè)試的例子:
//html代碼
<div class = "content">
<ul class = "list">
<li class = "liimg"><span class = "imgli img1"></span></li>
<li class = "liimg"><span class = "imgli img2"></span></li>
<li class = "liimg"><span class = "imgli img3"></span></li>
<li class = "liimg"><span class = "imgli img4"></span></li>
</ul>
</div>
css代碼
//css代碼
*{margin:0px;padding:0px;list-style-type:none;}
body{text-align:center;}
.content{width:590px;margin:0 auto;text-align:left;}
.list{width:565px;margin:0px 9px;border:1px solid #eee;padding:5px;display:inline-block;overflow:hidden;}
.liimg{padding:4px;border:1px solid #aaa;border-radius:2px;display:inline-block;*display:inline;*margin:0px 3px;background:#FFF;width:auto;}
.imgli{margin:2px 0px;width:125px;height:300px;display:inline-block;}
.img1{background:url(images/img1.jpg) no-repeat 50% 50%;}
.img2{background:url(images/img2.jpg) no-repeat 50% 50%;}
.img3{background:url(images/img3.jpg) no-repeat 50% 50%;}
.img4{background:url(images/img4.jpg) no-repeat 50% 50%;}
js代碼
//js代碼
//jquery實(shí)現(xiàn)圖片滑動(dòng)效果
var zyljq = $.noConflict();
zyljq.fn.extend({
slideW:function(wid,speed){
//wid要設(shè)置的寬度,可以設(shè)置變得最小時(shí)的寬度或者變得最大時(shí)的寬度
//如果不設(shè)置,則會(huì)根據(jù)綁定元素的寬度,計(jì)算設(shè)置默認(rèn)寬度。
//speed要設(shè)置的動(dòng)畫運(yùn)行速度,可以是normal,slow,fast,也可以是毫秒數(shù)。
//如果不設(shè)置,則默認(rèn)速度是normal
that = this; //綁定該事件的所有元素
var eleNum = zyljq(this).size(); //獲取圖片的數(shù)量
var curwidth = zyljq(this).width();//獲取圖片的原始寬度
if(!wid){
wid = Math.round(curwidth*4/5);
//如果沒(méi)有設(shè)置動(dòng)畫的終止條件,則計(jì)算出默認(rèn)的情況
}
if(zyljq.trim(speed) == ""){
//如果沒(méi)有設(shè)置速度,則取默認(rèn)速度
speed = "normal";
}
if(!isNaN(speed)){
//如果設(shè)置了負(fù)值,則變化
speed = speed < 0?-speed:speed;
}
//計(jì)算照片的最大和最小寬度
if(wid > curwidth){
widMin = Math.floor((eleNum*curwidth - wid)/(eleNum-1))+"px";
widMax = ((curwidth*eleNum) - widMin*(eleNum-1))+"px";
}else{
widMax = Math.floor((eleNum*curwidth - wid*(eleNum-1)))+"px";
widMin = wid+"px";
}
//console.log("widMax="+widMax+";widMin="+widMin);
//綁定hover事件
zyljq(this).hover(function(){
zyljq(that).stop();
zyljq(this).animate({width:widMax},speed);
zyljq(that).not(this).animate({width:widMin},speed);
},function(){
zyljq(that).stop();
zyljq(that).animate({width:curwidth},speed);
});
}
});
下面是視圖:
原始效果:
鼠標(biāo)懸停在第二個(gè)元素上之后的效果:
在這個(gè)過(guò)程中,也回顧了一些常見(jiàn)的問(wèn)題,比如:ie低版本下,margin:0 auto;不居中的問(wèn)題,display:inline-block;不支持的問(wèn)題。也許還有很多的問(wèn)題沒(méi)有注意到,如果您發(fā)現(xiàn)了什么問(wèn)題,歡迎您的指導(dǎo)。大家可以共同進(jìn)步。
下面是我自己測(cè)試的例子:
復(fù)制代碼 代碼如下:
//html代碼
<div class = "content">
<ul class = "list">
<li class = "liimg"><span class = "imgli img1"></span></li>
<li class = "liimg"><span class = "imgli img2"></span></li>
<li class = "liimg"><span class = "imgli img3"></span></li>
<li class = "liimg"><span class = "imgli img4"></span></li>
</ul>
</div>
css代碼
復(fù)制代碼 代碼如下:
//css代碼
*{margin:0px;padding:0px;list-style-type:none;}
body{text-align:center;}
.content{width:590px;margin:0 auto;text-align:left;}
.list{width:565px;margin:0px 9px;border:1px solid #eee;padding:5px;display:inline-block;overflow:hidden;}
.liimg{padding:4px;border:1px solid #aaa;border-radius:2px;display:inline-block;*display:inline;*margin:0px 3px;background:#FFF;width:auto;}
.imgli{margin:2px 0px;width:125px;height:300px;display:inline-block;}
.img1{background:url(images/img1.jpg) no-repeat 50% 50%;}
.img2{background:url(images/img2.jpg) no-repeat 50% 50%;}
.img3{background:url(images/img3.jpg) no-repeat 50% 50%;}
.img4{background:url(images/img4.jpg) no-repeat 50% 50%;}
js代碼
復(fù)制代碼 代碼如下:
//js代碼
//jquery實(shí)現(xiàn)圖片滑動(dòng)效果
var zyljq = $.noConflict();
zyljq.fn.extend({
slideW:function(wid,speed){
//wid要設(shè)置的寬度,可以設(shè)置變得最小時(shí)的寬度或者變得最大時(shí)的寬度
//如果不設(shè)置,則會(huì)根據(jù)綁定元素的寬度,計(jì)算設(shè)置默認(rèn)寬度。
//speed要設(shè)置的動(dòng)畫運(yùn)行速度,可以是normal,slow,fast,也可以是毫秒數(shù)。
//如果不設(shè)置,則默認(rèn)速度是normal
that = this; //綁定該事件的所有元素
var eleNum = zyljq(this).size(); //獲取圖片的數(shù)量
var curwidth = zyljq(this).width();//獲取圖片的原始寬度
if(!wid){
wid = Math.round(curwidth*4/5);
//如果沒(méi)有設(shè)置動(dòng)畫的終止條件,則計(jì)算出默認(rèn)的情況
}
if(zyljq.trim(speed) == ""){
//如果沒(méi)有設(shè)置速度,則取默認(rèn)速度
speed = "normal";
}
if(!isNaN(speed)){
//如果設(shè)置了負(fù)值,則變化
speed = speed < 0?-speed:speed;
}
//計(jì)算照片的最大和最小寬度
if(wid > curwidth){
widMin = Math.floor((eleNum*curwidth - wid)/(eleNum-1))+"px";
widMax = ((curwidth*eleNum) - widMin*(eleNum-1))+"px";
}else{
widMax = Math.floor((eleNum*curwidth - wid*(eleNum-1)))+"px";
widMin = wid+"px";
}
//console.log("widMax="+widMax+";widMin="+widMin);
//綁定hover事件
zyljq(this).hover(function(){
zyljq(that).stop();
zyljq(this).animate({width:widMax},speed);
zyljq(that).not(this).animate({width:widMin},speed);
},function(){
zyljq(that).stop();
zyljq(that).animate({width:curwidth},speed);
});
}
});
下面是視圖:
原始效果:

鼠標(biāo)懸停在第二個(gè)元素上之后的效果:

在這個(gè)過(guò)程中,也回顧了一些常見(jiàn)的問(wèn)題,比如:ie低版本下,margin:0 auto;不居中的問(wèn)題,display:inline-block;不支持的問(wèn)題。也許還有很多的問(wèn)題沒(méi)有注意到,如果您發(fā)現(xiàn)了什么問(wèn)題,歡迎您的指導(dǎo)。大家可以共同進(jìn)步。
您可能感興趣的文章:
- jQuery點(diǎn)擊后一組圖片左右滑動(dòng)的實(shí)現(xiàn)代碼
- 40個(gè)有創(chuàng)意的jQuery圖片、內(nèi)容滑動(dòng)及彈出插件收藏集之一
- 40個(gè)有創(chuàng)意的jQuery圖片和內(nèi)容滑動(dòng)及彈出插件收藏集之三
- jQuery插件Slider Revolution實(shí)現(xiàn)響應(yīng)動(dòng)畫滑動(dòng)圖片切換效果
- 40個(gè)有創(chuàng)意的jQuery圖片和內(nèi)容滑動(dòng)及彈出插件收藏集之二
- jQuery實(shí)現(xiàn)的Tab滑動(dòng)選項(xiàng)卡及圖片切換(多種效果)小結(jié)
- jquery animate圖片模向滑動(dòng)示例代碼
- JQuery實(shí)現(xiàn)簡(jiǎn)單的圖片滑動(dòng)切換特效
- jQuery實(shí)現(xiàn)圖片與文字描述左右滑動(dòng)自動(dòng)切換的方法
- jQuery實(shí)現(xiàn)圖片滑動(dòng)效果
相關(guān)文章
JQuery勾選指定name的復(fù)選框集合并顯示的方法
這篇文章主要介紹了JQuery勾選指定name的復(fù)選框集合并顯示的方法,涉及jQuery表單元素操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05jquery正則表達(dá)式驗(yàn)證(手機(jī)號(hào)、身份證號(hào)、中文名稱)
這篇文章主要介紹了jquery正則表達(dá)式驗(yàn)證,實(shí)現(xiàn)手機(jī)號(hào)、身份證號(hào)、中文名稱驗(yàn)證,感興趣的小伙伴們可以參考一下2015-12-12jquery validate添加自定義驗(yàn)證規(guī)則(驗(yàn)證郵箱 郵政編碼)
這篇文章主要介紹了query validate添加自定義驗(yàn)證規(guī)則,可以驗(yàn)證郵箱、郵政編碼等,看代碼參考使用2013-12-12jQuery基于ajax實(shí)現(xiàn)星星評(píng)論代碼
這篇文章主要介紹了jQuery基于ajax實(shí)現(xiàn)星星評(píng)論代碼,可實(shí)現(xiàn)實(shí)時(shí)顯示評(píng)論效果的功能,基于Ajax實(shí)現(xiàn),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08JQuery復(fù)選框全選效果如何實(shí)現(xiàn)
這篇文章主要介紹了JQuery復(fù)選框全選效果如何實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05jQuery基礎(chǔ)知識(shí)filter()和find()實(shí)例說(shuō)明
這是jQuery里常用的2個(gè)方法。他們2者功能是完全不同的,而初學(xué)者往往會(huì)被誤導(dǎo)。2010-07-07