成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導(dǎo)航首頁 ? 技術(shù)教程 ? jquery實現(xiàn)定時自動輪播特效
全站頭部文字 我要出現(xiàn)在這里
jquery實現(xiàn)定時自動輪播特效 651 2024-03-17   

這次的輪播圖是在上一篇文章jQuery手動點擊實現(xiàn)圖片輪播特效的基礎(chǔ)上寫出來的,也就是本次展示的是手動點擊輪播效果以及定時自動輪播效果的程序,建議想連貫學(xué)習(xí)的小伙伴把我之前的文章看一看,看完后再看這篇文章~~~~

下面來看看我做的最終定時自動輪播效果以及手動點擊輪播效果:

查看圖片

對于上面的展示動畫速度比較快的原因是因為我的截圖軟件是綠色版,免費的~~~你們懂得,就是卡卡的,真正的效果比這個速度慢,而且還是勻速,可以商用~~~所以上面的展示動畫只能當(dāng)做完成效果的參考。
一、主體程序

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8" />
 <title>輪播圖①(手動點擊輪播)</title>
 <link type="text/css" rel="stylesheet"  />
 </head>
 <body>
 <div class="slideShow">
  <圖片布局開始-->
  <ul>
  <li><a ><img src="http://www.gimoo.net/t/1904/img/picture01.jpg" /></a></li>
  <li><a ><img src="http://www.gimoo.net/t/1904/img/picture02.jpg" /></a></li>
  <li><a ><img src="http://www.gimoo.net/t/1904/img/picture03.jpg" /></a></li>
  <li><a ><img src="http://www.gimoo.net/t/1904/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="http://www.gimoo.net/t/1904/js/jquery-1.11.3.js"></script>
 <script src="http://www.gimoo.net/t/1904/js/layout.js"></script>
 </body>
</html>

額,上面的主體程序和前一篇沒有區(qū)別,未做任何修改~~~~~感興趣的可以查看第一篇文章,我本次隨筆重點會在Jquery程序里面
二、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;
}

三、jQuery程序
首先說一下定時自動輪播的原理:
1、首先得開一個定時器,假設(shè)定時器的時間設(shè)置為2000ms,也就是2S定時器執(zhí)行一次操作
2、定時器每隔2S執(zhí)行的操作就是模擬按次序點擊數(shù)字按鈕,也就是觸發(fā)click事件,讓圖片左移
先來看大體效果實現(xiàn)的jQuery代碼一

 var timer=null; //定時器返回值,主要用于關(guān)閉定時器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時首先顯示第一張圖,即索引值為0
 timer=setInterval(function(){ //打開定時器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click事件
 },2000); //2000為輪播的時間

上面的程序可以實現(xiàn)每隔2S圖片的輪播效果,但是輪播到最后一張圖的時候會停止,因為沒有判斷iNow是否到達最后一張圖,所以有了下面的代碼二:  

var timer=null; //定時器返回值,主要用于關(guān)閉定時器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時首先顯示第一張圖,即索引值為0
 timer=setInterval(function(){ //打開定時器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
 },2000); //2000為輪播的時間

所以jQuery程序的完整代碼程序如下:

$(document).ready(function(){
 var slideShow=$(".slideShow"), //獲取最外層框架的名稱
 ul=slideShow.find("ul"), 
 showNumber=slideShow.find(".showNav span"),//獲取按鈕
 oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個圖片的寬度
 var timer=null; //定時器返回值,主要用于關(guān)閉定時器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時首先顯示第一張圖,即索引值為0
 
 showNumber.on("click",function(){  //為每個按鈕綁定一個點擊事件 
  $(this).addClass("active").siblings().removeClass("active"); //按鈕點擊時為這個按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉
  var index=$(this).index(); //獲取哪個按鈕被點擊,也就是找到被點擊按鈕的索引值
  ul.animate({
  "left":-oneWidth*iNow, //注意此處用到left屬性,所以ul的樣式里面需要設(shè)置position: relative; 讓ul左移N個圖片大小的寬度,N根據(jù)被點擊的按鈕索引值index確定
  })
 });
 
 timer=setInterval(function(){ //打開定時器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
 },2000); //2000為輪播的時間
})

上面的注釋寫的很詳細了,主要是為了方便想學(xué)習(xí)的小伙伴看,但是實際上我寫程序不會注釋的那么詳細,都是很簡單的內(nèi)容啦,看到這里你可能以為jQuery程序就完了,那就大錯特錯了,因為自動輪播效果是正確的,但是手動點擊時就會出錯,我特意做了一段Gif動畫展示出錯的效果:

查看圖片

看到上面的效果你就會忽然大悟,圖片自動輪播時,你就算點擊按鈕它也只是附和你一下,跳轉(zhuǎn)到你點擊的按鈕,但是僅僅持續(xù)一會還是按它輪播的次序,不理會你點擊的按鈕后應(yīng)該走的輪播次序,至于原因嘛

是因為手動點擊時index的值未賦值給定時器的圖片索引iNow,這樣iNow就無法存儲你點擊的按鈕索引值,也就是不知道你點擊的哪個按鈕,既然知道了原因,那么下面就需要進行修改了。

修改完成后的jQuery程序最終版就是:

$(document).ready(function(){
 var slideShow=$(".slideShow"), //獲取最外層框架的名稱
 ul=slideShow.find("ul"), 
 showNumber=slideShow.find(".showNav span"),//獲取按鈕
 oneWidth=slideShow.find("ul li").eq(0).width(); //獲取每個圖片的寬度
 var timer=null; //定時器返回值,主要用于關(guān)閉定時器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時首先顯示第一張圖,即索引值為0
 
 showNumber.on("click",function(){  //為每個按鈕綁定一個點擊事件 
  $(this).addClass("active").siblings().removeClass("active"); //按鈕點擊時為這個按鈕添加高亮狀態(tài),并且將其他按鈕高亮狀態(tài)去掉
  var index=$(this).index(); //獲取哪個按鈕被點擊,也就是找到被點擊按鈕的索引值
  iNow=index;
  ul.animate({
  "left":-oneWidth*iNow, //注意此處用到left屬性,所以ul的樣式里面需要設(shè)置position: relative; 讓ul左移N個圖片大小的寬度,N根據(jù)被點擊的按鈕索引值iNOWx確定
  })
 });
 
 timer=setInterval(function(){ //打開定時器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
 },2000); //2000為輪播的時間
})

精彩專題分享:jQuery圖片輪播 JavaScript圖片輪播 Bootstrap圖片輪播

以上就是本文的全部內(nèi)容,下次就為大家分享鼠標(biāo)懸浮在輪播圖上方時圖片停止輪播,鼠標(biāo)移走后圖片接著進行輪播的代碼,不要走開。



主站蜘蛛池模板: 封顶仪式| 梁祝《引子》简谱| 七年级下册语文谁是最可爱的人笔记| 四查四看自我剖析材料| 清纯女被强行开了处视频| 我们结婚吧 电视剧| 韩宇辰| 卢昱晓电视剧| 林采薇| 好像怎么造句 二年级| 汤唯和梁朝伟拍戏原版视频在线观看| 啪啪电影网| 电影不扣钮的女孩| 王艺潼| frank sinatra| 红海行动2| free hd xxxx moms movie777| 北京卫视节目单今天| 河南省物业管理条例| 爱情三选一| 霸王茶姬喝了睡不着的原因| 张柏芝惊艳照片| 王牌御史| 爱爱免费视频观看| 约翰尼·西蒙斯| 陈牧驰个人资料简介图片| 流行性感冒ppt课件| 张天爱三级露全乳hd电影| 《生命中有你》赞美诗歌| 郑柔美个人简介| 欧比旺·克诺比| 九九九九九九伊人| 《月夜》电影| 消防给水及消火栓技术规范gb50974-2014| ..k| 男人上路| 世界上最有杀气的国歌| g71编程实例及解释| 爱情公寓海报| 蹲踞式跳远教案| 五年级第八单元作文|

!!!站長長期在線接!!!

網(wǎng)站、小程序:定制開發(fā)/二次開發(fā)/仿制開發(fā)等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103