亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

jquery實現定時自動輪播特效

2024-05-06 16:26:01
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了jquery實現定時自動輪播特效,講解內容很詳細,條理清晰,具有一定的參考價值,感興趣的小伙伴們可以參考一下
 

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

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

 jquery實現定時自動輪播特效

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

<!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>

額,上面的主體程序和前一篇沒有區別,未做任何修改~~~~~感興趣的可以查看第一篇文章,我本次隨筆重點會在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 : 對象不可層疊,但將依據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;}

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

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

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

var timer=null; //定時器返回值,主要用于關閉定時器  var iNow=0;  //iNow為正在展示的圖片索引值,當用戶打開網頁時首先顯示第一張圖,即索引值為0  timer=setInterval(function(){  //打開定時器   iNow++;       //讓圖片的索引值次序加1,這樣就可以實現順序輪播圖片   if(iNow>showNumber.length-1){ //當到達最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉到第一張圖重新開始    iNow=0;   }   showNumber.eq(iNow).trigger("click"); //模擬觸發數字按鈕的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; //定時器返回值,主要用于關閉定時器  var iNow=0;  //iNow為正在展示的圖片索引值,當用戶打開網頁時首先顯示第一張圖,即索引值為0    showNumber.on("click",function(){   //為每個按鈕綁定一個點擊事件     $(this).addClass("active").siblings().removeClass("active"); //按鈕點擊時為這個按鈕添加高亮狀態,并且將其他按鈕高亮狀態去掉   var index=$(this).index(); //獲取哪個按鈕被點擊,也就是找到被點擊按鈕的索引值   ul.animate({    "left":-oneWidth*iNow, //注意此處用到left屬性,所以ul的樣式里面需要設置position: relative; 讓ul左移N個圖片大小的寬度,N根據被點擊的按鈕索引值index確定   })  });    timer=setInterval(function(){  //打開定時器   iNow++;       //讓圖片的索引值次序加1,這樣就可以實現順序輪播圖片   if(iNow>showNumber.length-1){ //當到達最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉到第一張圖重新開始    iNow=0;   }   showNumber.eq(iNow).trigger("click"); //模擬觸發數字按鈕的click  },2000); //2000為輪播的時間})

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

jquery實現定時自動輪播特效

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

是因為手動點擊時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; //定時器返回值,主要用于關閉定時器  var iNow=0;  //iNow為正在展示的圖片索引值,當用戶打開網頁時首先顯示第一張圖,即索引值為0    showNumber.on("click",function(){   //為每個按鈕綁定一個點擊事件     $(this).addClass("active").siblings().removeClass("active"); //按鈕點擊時為這個按鈕添加高亮狀態,并且將其他按鈕高亮狀態去掉   var index=$(this).index(); //獲取哪個按鈕被點擊,也就是找到被點擊按鈕的索引值   iNow=index;   ul.animate({    "left":-oneWidth*iNow, //注意此處用到left屬性,所以ul的樣式里面需要設置position: relative; 讓ul左移N個圖片大小的寬度,N根據被點擊的按鈕索引值iNOWx確定   })  });    timer=setInterval(function(){  //打開定時器   iNow++;       //讓圖片的索引值次序加1,這樣就可以實現順序輪播圖片   if(iNow>showNumber.length-1){ //當到達最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉到第一張圖重新開始    iNow=0;   }   showNumber.eq(iNow).trigger("click"); //模擬觸發數字按鈕的click  },2000); //2000為輪播的時間})

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



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩激情片免费| 欧美人交a欧美精品| 亚洲欧美日韩一区在线| 日韩免费观看高清| 91精品国产免费久久久久久| 国产成人精品久久久| 一区二区欧美激情| 在线精品视频视频中文字幕| 久久久精品国产亚洲| 久久久亚洲影院你懂的| 日韩美女免费观看| 91在线观看免费观看| 国产做受高潮69| 日韩美女在线播放| 日韩精品免费视频| 亚洲视频一区二区| 亚洲免费av电影| 亚洲一区二区三区在线免费观看| 亚洲国产精品久久91精品| 一区二区三区高清国产| 色诱女教师一区二区三区| 在线观看日韩视频| 久久免费视频这里只有精品| 欧美亚洲另类制服自拍| 亚洲欧美日韩国产中文专区| 欧美成人精品激情在线观看| 亚洲人成网站在线播| 日韩欧美视频一区二区三区| 欧日韩不卡在线视频| 久久视频免费观看| 亚洲乱码国产乱码精品精天堂| 亚洲精品视频二区| 福利二区91精品bt7086| 97热精品视频官网| 日韩中文在线观看| 久久久精品一区二区三区| 国产一区二区美女视频| 国产精品久久久久久久9999| 一夜七次郎国产精品亚洲| 51精品国产黑色丝袜高跟鞋| 欧美在线精品免播放器视频| 亚洲欧洲免费视频| 久久99久久99精品中文字幕| 欧美激情综合色综合啪啪五月| 久久久在线免费观看| 国产精品第一第二| 久久久久亚洲精品| 欧美日韩在线免费观看| 久久国产精品影视| 国产丝袜精品视频| 国产精品第七影院| 久久久久久久香蕉网| 久久亚洲精品中文字幕冲田杏梨| 伊人伊成久久人综合网站| 久久精品亚洲94久久精品| 91成人在线观看国产| 欧美乱妇40p| 欧美激情喷水视频| 精品欧美aⅴ在线网站| 亚洲日本中文字幕免费在线不卡| 日韩午夜在线视频| 在线视频一区二区| 一区二区三欧美| 中文字幕综合在线| 欧美成人免费在线观看| 亚洲免费一级电影| 中文日韩在线观看| 亚洲人成网站免费播放| 欧美激情小视频| 中文字幕一区电影| 深夜福利91大全| 亚洲欧美国产高清va在线播| 欧美黄色片视频| 欧美性xxxx极品hd欧美风情| 欧美电影免费观看高清| 亚洲国产精品久久久久秋霞不卡| 国产精品久久久久久婷婷天堂| 国产精品久久久久久久app| 日韩欧美a级成人黄色| 最近更新的2019中文字幕| 国产中文字幕亚洲| 91久久久久久久久久久久久| 国产精品中文在线| 久久国产精品网站| 91po在线观看91精品国产性色| 欧美日韩性生活视频| 欧美午夜视频在线观看| 亚洲精品电影网| 欧美电影在线免费观看网站| 色青青草原桃花久久综合| 国产黑人绿帽在线第一区| 91精品免费视频| 日韩精品亚洲精品| 国产日韩综合一区二区性色av| 欧美丰满片xxx777| 日本精品视频在线观看| 精品高清美女精品国产区| 国产69久久精品成人| 日韩欧美国产成人| 日韩中文字幕免费看| 亚洲成av人影院在线观看| 日韩av免费看| 欧美乱大交做爰xxxⅹ性3| 亚洲欧洲日产国码av系列天堂| 亚洲国产高潮在线观看| 欧美在线观看网址综合| 久久影视电视剧凤归四时歌| 国产精品视频999| 96pao国产成视频永久免费| 欧美精品在线看| 国产精品视频专区| 91wwwcom在线观看| 久久乐国产精品| 亚洲美女免费精品视频在线观看| 国产精品99久久久久久久久久久久| 国内精品久久久久久久| 欧美日韩亚洲激情| 国产成人高潮免费观看精品| 97香蕉超级碰碰久久免费软件| 国产午夜精品全部视频在线播放| 亚洲第一黄色网| 国产亚洲精品久久久久久| 精品一区二区三区电影| 91禁国产网站| 国产精品久久久久久久久久小说| 欧美精品久久久久a| 欧美另类69精品久久久久9999| 国产亚洲一区精品| 91免费在线视频| 黑人狂躁日本妞一区二区三区| 亚洲日本成人网| 日韩美女视频在线观看| 97久久伊人激情网| 国产综合香蕉五月婷在线| 欧美成人精品不卡视频在线观看| 成人网在线视频| 亚洲人成网站色ww在线| 久久久久久久久久亚洲| 中文字幕亚洲一区二区三区五十路| 亚洲a∨日韩av高清在线观看| 色综合五月天导航| 亚洲精品720p| 久久国产视频网站| 亚洲男人天天操| 91在线色戒在线| 国产在线不卡精品| 亚洲激情在线观看视频免费| 欧美日韩国产精品一区二区不卡中文| 欧美性猛交99久久久久99按摩| 亚洲欧美日韩直播| 51久久精品夜色国产麻豆| 一本色道久久综合狠狠躁篇怎么玩| 在线视频亚洲欧美| 一个人看的www久久| 亚洲精品98久久久久久中文字幕| 日韩av电影中文字幕| 久久成人精品电影| 亚洲成人中文字幕| 欧美成人免费全部观看天天性色| 亚洲国产欧美自拍| 亚洲人成电影网站色xx| 亚洲午夜色婷婷在线| 91久久夜色精品国产网站| 日韩hd视频在线观看|