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

導(dǎo)航首頁 ? 技術(shù)教程 ? jquery實現(xiàn)鼠標懸浮停止輪播特效
全站頭部文字 我要出現(xiàn)在這里
jquery實現(xiàn)鼠標懸浮停止輪播特效 639 2024-03-17   

本文實例講述了jquery實現(xiàn)鼠標懸浮停止輪播特效代碼。分享給大家供大家參考。具體如下:
運行效果截圖如下:

查看圖片

具體代碼如下:

一、主體程序

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

二、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、當鼠標懸浮在框架上方時,清除定時器即用clearInterval(timer)關(guān)閉定時器,使自動輪播停止 2、當鼠標離開框架上方時,重新啟動定時器 3、鼠標的懸浮和離開借助于hover函數(shù)

hover(over,out)一個模仿懸停事件(鼠標移動到一個對象上面及移出這個對象)的方法。這是一個自定義的方法,它為頻繁使用的任務(wù)提供了一種“保持在其中”的狀態(tài)。
參數(shù):
over (Function) : 鼠標移到元素上要觸發(fā)的函數(shù)。
out (Function): 鼠標移出元素要觸發(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(); //獲取每個圖片的寬度
  var timer=null; //定時器返回值,主要用于關(guān)閉定時器
  var iNow=0;  //iNow為正在展示的圖片索引值,當用戶打開網(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ù)被點擊的按鈕索引值iNow確定
   })
  });
  /*手動點擊按鈕進行圖片輪播代碼結(jié)束*/
  
  
  /*定時自動輪播圖片代碼開始*/
  timer=setInterval(function(){  //打開定時器
   iNow++;       //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
   if(iNow>showNumber.length-1){ //當?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
    iNow=0;
   }
   showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
  },2000); //2000為輪播的時間
  /*定時自動輪播圖片代碼結(jié)束*/
  
  /*鼠標懸浮圖片停止輪播代碼開始*/
  slideShow.hover(
   function(){
    clearInterval(timer);
   },function(){
    timer=setInterval(function(){  //打開定時器
     iNow++;       //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
     if(iNow>showNumber.length-1){ //當?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
      iNow=0;
     }
     showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
    },2000); //2000為輪播的時間
   }
  );
  /*鼠標懸浮圖片停止輪播代碼結(jié)束*/
})

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

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

定義完成后不要忘記調(diào)用這個函數(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(); //獲取每個圖片的寬度
  var timer=null; //定時器返回值,主要用于關(guān)閉定時器
  var iNow=0;  //iNow為正在展示的圖片索引值,當用戶打開網(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ù)被點擊的按鈕索引值iNow確定
   })
  });
  /*手動點擊按鈕進行圖片輪播代碼結(jié)束*/
  
  
  /*定時自動輪播圖片代碼開始*/
  function autoPlay(){
   timer=setInterval(function(){  //打開定時器
   iNow++;       //讓圖片的索引值次序加1,這樣就可以實現(xiàn)順序輪播圖片
   if(iNow>showNumber.length-1){ //當?shù)竭_最后一張圖的時候,讓iNow賦值為第一張圖的索引值,輪播效果跳轉(zhuǎn)到第一張圖重新開始
    iNow=0;
   }
   showNumber.eq(iNow).trigger("click"); //模擬觸發(fā)數(shù)字按鈕的click
   },2000); //2000為輪播的時間
  }
  autoPlay();
  /*定時自動輪播圖片代碼結(jié)束*/
  
  /*鼠標懸浮圖片停止輪播代碼開始*/
  slideShow.hover(
   function(){
    clearInterval(timer);
   },autoPlay
  );
  /*鼠標懸浮圖片停止輪播代碼結(jié)束*/
})

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

文章一:jQuery手動點擊實現(xiàn)圖片輪播特效

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

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

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



主站蜘蛛池模板: 诈欺游戏电影| 田教授的28个保姆演员表| 朱莉·安妮| 吃屎视频搞笑视频| 装饰色彩| 芭芭拉·布薛特| https://www.douyin.com| 火烈鸟电影完整版视频| 山东卫视节目表| 二年级100个数学应用题| 小池里奈| 最可爱的人 电影| 庞勇| 玉匣记全文免费| 菊花开| 驯服型男刑警队长| 电影喜剧明星演员表| 孙子兵法三十六计完整解释电子书| 美女网站视频在线| 抖音 网页版| 乱世危情电视剧演员表| angela white电影| 少女模特电影| 黄霄云个人资料| 吴汉润| 偏偏喜欢你演员表| 车辆年检新规几年一审| 《魔》| 唐人街探案5免费完整观看| 电影 英雄| 法国地图| 林连昆| 电影《金刚川》| 三年级英语| 汪始慧| 机械师3| 扎西顿珠的个人资料简介| 玉林电视台| 孙颖莎结婚视频| 1—36集电视剧在线观看| 按摩服务电影|

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

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

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

站長微信:lxwl520520

站長QQ:1737366103