欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery實(shí)現(xiàn)鼠標(biāo)懸浮停止輪播特效

 更新時(shí)間:2020年08月20日 15:11:06   作者:Sunshine_lily  
這篇文章主要介紹了jquery實(shí)現(xiàn)鼠標(biāo)懸浮停止輪播特效,鼠標(biāo)懸停在圖片上則停止輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例講述了jquery實(shí)現(xiàn)鼠標(biāo)懸浮停止輪播特效代碼。分享給大家供大家參考,具體如下:

運(yùn)行效果截圖如下:

具體代碼如下:

一、主體程序

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

二、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 : 對(duì)象不可層疊,但將依據(jù)left,right,top,bottom等屬性在正常文檔流中偏移位置,如果沒有這個(gè)屬性,圖片將不可左右移動(dòng)*/
}
.slideShow ul li{
 float: left; /*讓四張圖片左浮動(dòng),形成并排的橫著布局,方便點(diǎn)擊按鈕時(shí)的左移動(dòng)*/
 width: 346px;
}
.slideShow .showNav{ /*用絕對(duì)定位給數(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;
}

三、jQuery程序

先說一下鼠標(biāo)懸浮圖片輪播停止的原理:

  • 1、當(dāng)鼠標(biāo)懸浮在框架上方時(shí),清除定時(shí)器即用clearInterval(timer)關(guān)閉定時(shí)器,使自動(dòng)輪播停止
  • 2、當(dāng)鼠標(biāo)離開框架上方時(shí),重新啟動(dòng)定時(shí)器
  • 3、鼠標(biāo)的懸浮和離開借助于hover函數(shù)

hover(over,out)一個(gè)模仿懸停事件(鼠標(biāo)移動(dòng)到一個(gè)對(duì)象上面及移出這個(gè)對(duì)象)的方法。這是一個(gè)自定義的方法,它為頻繁使用的任務(wù)提供了一種“保持在其中”的狀態(tài)。

參數(shù):

over (Function) : 鼠標(biāo)移到元素上要觸發(fā)的函數(shù)。
out (Function): 鼠標(biāo)移出元素要觸發(fā)的函數(shù)。

下面來看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è)圖片的寬度
 var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時(shí)首先顯示第一張圖,即索引值為0
 
 /*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼開始*/
 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)擊按鈕的索引值
  iNow=index;
  ul.animate({
  "left":-oneWidth*iNow, //注意此處用到left屬性,所以u(píng)l的樣式里面需要設(shè)置position: relative; 讓ul左移N個(gè)圖片大小的寬度,N根據(jù)被點(diǎn)擊的按鈕索引值iNow確定
  })
 });
 /*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼結(jié)束*/
 
 
 /*定時(shí)自動(dòng)輪播圖片代碼開始*/
 timer=setInterval(function(){ //打開定時(shí)器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
 },2000); //2000為輪播的時(shí)間
 /*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/
 
 /*鼠標(biāo)懸浮圖片停止輪播代碼開始*/
 slideShow.hover(
  function(){
  clearInterval(timer);
  },function(){
  timer=setInterval(function(){ //打開定時(shí)器
   iNow++;    //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
   if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
   iNow=0;
   }
   showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
  },2000); //2000為輪播的時(shí)間
  }
 );
 /*鼠標(biāo)懸浮圖片停止輪播代碼結(jié)束*/
})

從上圖可以看出開啟定時(shí)器的代碼是重復(fù)的,所以這里可以定義一個(gè)自動(dòng)播放的函數(shù)autoPlay()來精簡代碼,經(jīng)過精簡后的代碼如下:

/*定時(shí)自動(dòng)輪播圖片代碼開始*/
 function autoPlay(){
  timer=setInterval(function(){ //打開定時(shí)器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
  },2000); //2000為輪播的時(shí)間
 }
 autoPlay();
 /*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/

定義完成后不要忘記調(diào)用這個(gè)函數(shù),即autoPlay();
那么最終版的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è)圖片的寬度
 var timer=null; //定時(shí)器返回值,主要用于關(guān)閉定時(shí)器
 var iNow=0; //iNow為正在展示的圖片索引值,當(dāng)用戶打開網(wǎng)頁時(shí)首先顯示第一張圖,即索引值為0
 
 /*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼開始*/
 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)擊按鈕的索引值
  iNow=index;
  ul.animate({
  "left":-oneWidth*iNow, //注意此處用到left屬性,所以u(píng)l的樣式里面需要設(shè)置position: relative; 讓ul左移N個(gè)圖片大小的寬度,N根據(jù)被點(diǎn)擊的按鈕索引值iNow確定
  })
 });
 /*手動(dòng)點(diǎn)擊按鈕進(jìn)行圖片輪播代碼結(jié)束*/
 
 
 /*定時(shí)自動(dòng)輪播圖片代碼開始*/
 function autoPlay(){
  timer=setInterval(function(){ //打開定時(shí)器
  iNow++;    //讓圖片的索引值次序加1,這樣就可以實(shí)現(xiàn)順序輪播圖片
  if(iNow>showNumber.length-1){ //當(dāng)?shù)竭_(dá)最后一張圖的時(shí)候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
  iNow=0;
  }
  showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
  },2000); //2000為輪播的時(shí)間
 }
 autoPlay();
 /*定時(shí)自動(dòng)輪播圖片代碼結(jié)束*/
 
 /*鼠標(biāo)懸浮圖片停止輪播代碼開始*/
 slideShow.hover(
  function(){
  clearInterval(timer);
  },autoPlay
 );
 /*鼠標(biāo)懸浮圖片停止輪播代碼結(jié)束*/
})

以上就是本文的全部內(nèi)容,大家可以結(jié)合下面這兩篇文章進(jìn)行學(xué)習(xí):

文章一:jQuery手動(dòng)點(diǎn)擊實(shí)現(xiàn)圖片輪播特效

文章二:jquery實(shí)現(xiàn)定時(shí)自動(dòng)輪播特效

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

希望本文所述對(duì)大家學(xué)習(xí)jQuery程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論