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

首頁 > 編程 > JavaScript > 正文

基于jquery實現百度新聞導航菜單滑動動畫

2019-11-20 10:23:20
字體:
來源:轉載
供稿:網友

本文實例為大家分享jquery實現百度新聞導航菜單滑動動畫,供大家參考,具體內容如下

思路與步驟
1.利用UL創建簡單橫向導航;

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head>  <title>仿百度新聞菜單滑動動畫</title>  <style type="text/css">    body, div, ul, li, a    {      margin: 0px;      padding: 0px;      font-size: 20px;      color: #FFF;      border: 0;    }    .div-nav-container    {      margin-top: 50px;      width: 100%;      background-color: #01204F;    }    .div-nav    {      width: 870px;      margin: 0px auto;    }    ul    {      list-style: outside none none;      width: 100%;      height: 50px;    }    ul li    {      float: left;    }    ul li a    {      line-height: 50px;      display: block;      padding: 0px 15px;      text-align: center;      text-decoration: none;    }  </style></head><body>  <div class="div-nav-container">    <div class="div-nav">      <ul>        <li><a href="javascript:void(0)">網站首頁</a></li>        <li><a href="javascript:void(0)">熱點</a> </li>        <li><a href="javascript:void(0)">國際新聞</a> </li>        <li><a href="javascript:void(0)">國內新聞</a> </li>        <li><a href="javascript:void(0)">國家政策</a> </li>        <li><a href="javascript:void(0)">體育新聞</a> </li>        <li><a href="javascript:void(0)">娛樂新聞</a> </li>        <li><a href="javascript:void(0)">名人</a> </li>        <li><a href="javascript:void(0)">古跡</a> </li>      </ul>    </div>  </div></body></html>

2.添加一個脫離層的div,命名div-hover,用于菜單滑動動畫,設置CSS樣式;

<style type="text/css">  .div-hover  {   background-color: Red;height: 50px;   left: 0px;   top: 0px;   width: 0px;  }</style><div class="div-nav">   <!--添加滑動背景-->   <div class="div-hover">   </div>   <ul>     ...   </ul></div>

3.添加菜單項的滑動事件,計算div-hover的滑動要素,左,上邊距以及寬度;

<script type="text/javascript">  var divHoverLeft = 0;  var aWidth = 0;  $(document).ready(function () {    $("a").on({      'mouseover': function () {        SetDivHoverWidthAndLeft(this);        //設置滑動動畫        $(".div-hover").stop().animate({ width: aWidth, left: divHoverLeft }, 150);      }    });  });  function SetDivHoverWidthAndLeft(element) {    divHoverLeft = GetLeft(element);    aWidth = GetWidth(element);  }  //獲得Li寬度  function GetWidth(ele) {   return $(ele).parent().width();  }  //獲得div-hover左邊距  function GetLeft(element) {   //獲得li之前的同級li元素   var menuList = $(element).parent().prevAll();   var left = 0;   //計算背景遮罩左邊距   $.each(menuList, function (index, ele) {    left += $(ele).width();   });   return left; }</script>

效果預覽

從預覽效果可以看出,div-hover的定位是有問題的,div-hover應該以父級元素絕對定位,所以修改代碼(注釋部分為修改點)如下:

<style type="text/css">  .div-nav  {    width: 870px;    margin: 0px auto;    /*作為div-hover的父元素定位參照*/    position: relative;  }  .div-hover  {    background-color: Red;    height: 50px;    left: 0px;    top: 0px;    width: 0px;    /*以父元素絕對定位*/    position: absolute;  }</style>

雖然解決了定位問題,但是背景圖片還是浮于文字上方,所以調整代碼,將文字浮動于紅色div之上:

<style type="text/css">  ul li  {    float: left;     /*****Start(作用:導航文字浮于div-hover紅色之上)*******/    position: relative;    z-index: 4;     /*********************End*************************/  }</style>

效果預覽

4.添加菜單點擊,以及加載頁面默認菜單選中;

<style type="text/css">  /**設置菜單激活***/  .active  {    background-color: Red;  }</style><script type="text/javascript">  var divHoverLeft = 0;  var aWidth = 0;  $(document).ready(function () {    $("a").on({      'mouseover': function () {        SetDivHoverWidthAndLeft(this);        //設置滑動動畫        $(".div-hover").stop().animate({ width: aWidth, left: divHoverLeft }, 150);      },      /*添加點擊事件*/      'click': function () {        SetDivHoverWidthAndLeft(this);        //清除所有a標簽class        $('a').removeClass();        //設置當前點擊菜單為激活狀態        $(this).addClass('active');      }    });  });</script></head><body>  <div class="div-nav-container">    <div class="div-nav">      <!--添加滑動背景-->      <div class="div-hover">      </div>      <ul>        <--默認菜單激活-->         <li><a class="active" href="javascript:void(0)">網站首頁</a></li>        …………      </ul>    </div>  </div></body></html>

效果預覽

5.添加鼠標移出范圍,自動定位當前激活元素功能;

      在做此功能之前,先理下思路,鼠標移出操作,我們可以想到mouseout,mouseleave事件,那么隨之就會有以下幾個疑問:

       ①這地方選用哪個事件可以滿足這個條件呢?

       ②那選擇的事件又定位在哪個元素呢?

       ③移出鼠標之后又如何知道當前激活的是哪個元素呢?

       ④如何知道div-hover的左邊距和width等值呢?

      實踐出真知,那就實踐一下:

       首先,以mouseout為例,第一個問題自然就解決了;

       其次,事件定位在哪個元素?通過上面GIF圖,分析,如果定位在A標簽或Li標簽,那么鼠標移出操作在A標簽或Li標簽之間切換也會觸發自動定位到激活元素(假設自動定位已做),就會出現如下圖所示情況:

所以不能定位在A或Li標簽上,再想一下,鼠標應該是移出整個導航的范圍才可以,那么定位在哪個元素就很容易出來了,應該定位在UL或者UL的父級元素,他們兩個的大小范圍均是一致的,所以兩個元素均可以,若兩個元素大小不一致,就應該定位在UL上面了。于是就有了類似如下代碼:

$("ul").on({   'mouseout': function (event) {      /*動畫定位div-hover位置到激活元素*/    }});

      然后,如何知道當前激活為何元素呢,可以在點擊事件時,用隱藏域或者其他display方式存儲當前點擊的元素寬度和左邊距,待鼠標移出操作,重新讀取存儲的數據,進而進行animate定位;從而解決以上③④問題;部分代碼如下:

(當然,想知道菜單激活元素,也可以用class為active的方式來查找,不過這種方式,相對來說麻煩一些,首先獲得active的元素,然后通過遍歷li,重新計算一遍寬度和左邊距,最后進行賦值和添加滑動定位;此處暫用隱藏域方式處理,原因是方便簡單,群友如有興趣可以用active方式試驗)

<script type="text/javascript">   var divHoverLeft = 0;   var aWidth = 0;   $(document).ready(function () {    //菜單滑動動畫     $("a").on({       'mouseover': function () {         SetDivHoverWidthAndLeft(this);         //設置滑動動畫          $(".div-hover").stop().animate({ width: aWidth, left: divHoverLeft }, 150);       }'click': function () {         SetDivHoverWidthAndLeft(this);         //清除所有a標簽class         $('a').removeClass();         //設置當前點擊菜單為激活狀態          $(this).addClass('active');         $(".h-width").val(aWidth);         $(".h-left").val(divHoverLeft);       }     });     /*鼠標滑出UL或者div-nav背景div-hover自動定位到激活菜單處*/     $("ul").on({       'mouseout': function (event) {         $(".div-hover").stop().animate({ width: $(".h-width").val(), left: $(".h-left").val() }, 150);       }     });  });  function SetDivHoverWidthAndLeft(element) {    divHoverLeft = GetLeft(element);    aWidth = GetWidth(element);  }  ............  </script></head><body>  <div class="div-nav-container">    <div class="div-nav">      <!--添加滑動背景-->      <div class="div-hover">      </div>      <ul>        <li><a class="active" href="javascript:void(0)">網站首頁</a></li>        ...........      </ul>    </div>  </div>  <input type="hidden" class="h-width" value="110" />  <input type="hidden" class="h-left" value="0" /></body></html>

效果展示:

看圖發現依舊出現之前類似定位在A或Li的問題,出現這種情況的原因:

jquery中mouseout如果定位在一個元素上,例如div,那么此div之下的元素都會具有mouseout事件,也就是常說的,事件冒泡機制;與此類似的事件如mousedown,mouseover等,那么是不是阻止事件冒泡就行了呢? 理論上是這樣的。通常阻止冒泡有兩種方式: event.stopPropagation();和return false;當然他們之間也是有區別的。

相關代碼修改如下:

<script type="text/javascript">    ..........    $(document).ready(function () {       /*鼠標滑出UL或者div-nav背景div-hover自動定位到激活菜單處*/      $("ul").on({        'mouseout': function (event) {          $(".div-hover").stop().animate({ width: $(".h-width").val(), left: $(".h-left").val() }, 150);          /**阻止冒泡**/          event.stopPropagation();          //return false;        }      });    });    .......</script>

無論何種阻止方式,都沒有卵用,依舊阻止不了冒泡,效果可想而知,與上面Gif圖所示無異;

由此證明,mouseover在實現此功能方面是有問題的;

那換mouseleave呢,除了將mouseover修改為mouseleave和去除冒泡代碼外,其他代碼不做改動,實驗效果如下:

從上圖可以看出,效果與百度新聞導航滑動基本無異,至此大功告成;

完整代碼

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head>  <title>仿百度新聞菜單滑動動畫</title>  <style type="text/css">    body, div, ul, li, a    {      margin: 0px;      padding: 0px;      font-size: 20px;      color: #FFF;      border: 0;    }    .div-nav-container    {      margin-top: 50px;      width: 100%;      background-color: #01204F;    }    .div-nav    {      /*作為div-hover的父元素定位參照*/      position: relative;      width: 870px;      margin: 0px auto;    }    .div-hover    {      background-color: Red;      /*以父元素絕對定位*/      position: absolute;      height: 50px;      left: 0px;      top: 0px;      width: 0px;    }    ul    {      list-style: outside none none;      width: 100%;      height: 50px;    }    ul li    {      float: left;      /*****Start(作用:導航文字浮于div-hover紅色之上)*******/      position: relative;      z-index: 4;      /*********************End*************************/    }    ul li a    {      line-height: 50px;      display: block;      padding: 0px 15px;      text-align: center;      text-decoration: none;    }    /**設置菜單激活***/    .active    {      background-color: Red;    }  </style>  <script src="../js/jquery-1.11.3.min.js" type="text/javascript"></script>  <script type="text/javascript">    var divHoverLeft = 0;    var aWidth = 0;    $(document).ready(function () {      //菜單滑動動畫      $("a").on({         /*此處用mouseover或者mouseenter均可,如果以后要為X標簽同時添加懸停和移出事件,建議用enter和leave也就是傳說中的hover事件,因為里面事件冒泡已經處理過,就不會出現類似over和out之類的情況了*/        'mouseenter': function () {          SetDivHoverWidthAndLeft(this);          //設置滑動動畫           $(".div-hover").stop().animate({ width: aWidth, left: divHoverLeft }, 150);        },        'click': function () {          SetDivHoverWidthAndLeft(this);          //清除所有a標簽class          $('a').removeClass();          //設置當前點擊菜單為激活狀態          $(this).addClass('active');          $(".h-width").val(aWidth);          $(".h-left").val(divHoverLeft);        }      });      /*鼠標滑出UL或者div-nav背景div-hover自動定位到激活菜單處*/      //mouseleave事件定位到ul或者div-nav均可      $("ul").on({        'mouseleave': function (event) {          $(".div-hover").stop().animate({ width: $(".h-width").val(), left: $(".h-left").val() }, 150);        }      });    });    function SetDivHoverWidthAndLeft(element) {      divHoverLeft = GetLeft(element);      aWidth = GetWidth(element);    }    //獲得Li寬度    function GetWidth(ele) {      return $(ele).parent().width();    }    //獲得div-hover左邊距    function GetLeft(element) {      //獲得li之前的同級li元素      var menuList = $(element).parent().prevAll();      var left = 0;      //計算背景遮罩左邊距      $.each(menuList, function (index, ele) {        left += $(ele).width();     });     return left;    }  </script></head><body>  <div class="div-nav-container">    <div class="div-nav">      <!--添加滑動背景-->      <div class="div-hover">      </div>      <ul>        <li><a class="active" href="javascript:void(0)">網站首頁</a></li>        <li><a href="javascript:void(0)">熱點</a> </li>        <li><a href="javascript:void(0)">國際新聞</a> </li>        <li><a href="javascript:void(0)">國內新聞</a> </li>        <li><a href="javascript:void(0)">國家政策</a> </li>        <li><a href="javascript:void(0)">體育新聞</a> </li>        <li><a href="javascript:void(0)">娛樂新聞</a> </li>        <li><a href="javascript:void(0)">名人</a> </li>        <li><a href="javascript:void(0)">古跡</a> </li>      </ul>    </div>  </div>  <input type="hidden" class="h-width" value="110" />  <input type="hidden" class="h-left" value="0" /></body></html>

總結和關鍵點
1.背景滑動由某個塊狀元素(此處用的div)來實現,而非本元素的hover改變背景顏色;

2.注意元素定位(滑動塊狀元素以誰來絕對定位或者相對定位,左邊距的計算和自身寬度的計算;滑動塊狀元素div-hover和li之間的相對定位,以及層級大小);

3.滑動動畫事件animate和記錄激活菜單,鼠標移出區域自定定位到激活菜單;

4.jquery中mouseover,mouseout以及mouseenter,mouseleave關于冒泡機制的區別;(前兩個未做冒泡機制的限制,后兩個冒泡已經經過處理,事件只針對注冊元素本身,而不會對子元素起作用,mouseenter和mouseleave用在一個元素標簽上可以用hover事件代替,本身hover就是這兩者的封裝,如果事件在不同元素標簽上,最好分開調用mouseenter和mouseleave事件)

5.所有關鍵點以及作用都已經在代碼各處加上注釋,各位可以看看。

希望本文對大家學習jquery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本一区二三区好的精华液| 欧美成人国产va精品日本一级| 日韩欧美精品中文字幕| 成人夜晚看av| 日韩中文字幕第一页| 国产在线高清精品| 国产精品pans私拍| 国产精品亚洲视频在线观看| 国产精品一区二区三区久久| 国产乱肥老妇国产一区二| 久久久女人电视剧免费播放下载| 色久欧美在线视频观看| 欧美精品激情blacked18| 国产精品视频26uuu| 成人午夜激情网| 中文字幕亚洲无线码a| 亚洲一二三在线| 久久九九精品99国产精品| 亚洲国产精品中文| 国产不卡一区二区在线播放| 日韩精品中文字幕在线播放| 成人黄色激情网| 亚洲激情在线观看视频免费| 日韩精品视频在线免费观看| 久久精品国产欧美亚洲人人爽| 久久亚洲精品网站| 亚洲跨种族黑人xxx| 亚洲国产欧美在线成人app| 久久精品电影网| 97碰碰碰免费色视频| 国产精品9999| 亚洲欧美日韩视频一区| 国产suv精品一区二区| 亚洲视频综合网| 日韩激情视频在线播放| 亚洲人av在线影院| 欧美性生交大片免费| 国产精品国产自产拍高清av水多| 午夜精品久久久久久久白皮肤| 岛国av一区二区| 欧美高清视频在线| 日韩国产精品视频| 国产在线播放不卡| 宅男66日本亚洲欧美视频| 欧美黄色片免费观看| 亚洲精品按摩视频| 欧美激情啊啊啊| 国产一区二区三区四区福利| 91色视频在线导航| 欧美极品少妇xxxxx| 亚洲аv电影天堂网| 亚洲国产成人av在线| 欧美在线欧美在线| 欧美成人免费网| 亚洲精品在线观看www| 亚洲精品中文字幕有码专区| 在线午夜精品自拍| 久久成年人视频| 欧美老女人bb| 久操成人在线视频| 亚洲综合日韩中文字幕v在线| 亚洲国产成人av在线| 日本精品在线视频| 国产欧美日韩精品丝袜高跟鞋| 亚洲第一页自拍| 国产一区视频在线| 欧美日韩国产综合新一区| 国产第一区电影| 91香蕉嫩草神马影院在线观看| 亚洲欧美国产高清va在线播| 国产精品久久久久久亚洲影视| 日韩最新在线视频| 91九色国产社区在线观看| 欧洲亚洲女同hd| 在线观看国产欧美| 国产精品一区二区三区成人| 久久人体大胆视频| 国产精品欧美日韩一区二区| 精品性高朝久久久久久久| 日韩免费视频在线观看| 亚洲国产精品va在线观看黑人| 热门国产精品亚洲第一区在线| 欧美多人爱爱视频网站| 亚洲free性xxxx护士白浆| 日韩精品在线看| 热久久这里只有| 国产亚洲视频中文字幕视频| 久久精品国产视频| 中文字幕久热精品在线视频| 亚洲欧美激情另类校园| 国产精品第一区| 亚洲性69xxxbbb| 日韩成人av网址| 国产精品99导航| 欧美午夜精品久久久久久人妖| 日韩成人高清在线| 成人有码在线视频| 国产成人av网| 国产91亚洲精品| 夜夜嗨av色一区二区不卡| 色婷婷综合久久久久| 亚洲第一在线视频| 日本久久中文字幕| 欧美亚洲另类激情另类| 亚洲精品美女久久久久| 国产日本欧美一区二区三区在线| 中文亚洲视频在线| 热久久视久久精品18亚洲精品| 亚洲黄色www网站| 中文.日本.精品| 亚洲新中文字幕| 亚洲精品美女在线观看播放| 亚洲欧美中文日韩v在线观看| 91在线国产电影| 久久99精品久久久久久琪琪| 中文字幕精品影院| 91av免费观看91av精品在线| 成人精品网站在线观看| 成人av.网址在线网站| 亚洲欧美激情在线视频| 亚洲国产91精品在线观看| 午夜精品理论片| 久久人人爽人人爽人人片亚洲| 亚洲最新中文字幕| 亚洲一区二区三区视频播放| 日韩精品一区二区视频| 亚洲精品福利在线| 国产精品∨欧美精品v日韩精品| 成人性生交大片免费看视频直播| 亚洲午夜未满十八勿入免费观看全集| 亚洲一区二区三区视频播放| 奇米4444一区二区三区| 欧美做受高潮电影o| 在线观看久久久久久| 国产精品黄页免费高清在线观看| 欧美专区中文字幕| 国产经典一区二区| 欧美日本中文字幕| 97在线日本国产| 68精品国产免费久久久久久婷婷| 亚洲精品国产精品自产a区红杏吧| 亚洲天堂第一页| 欧美尤物巨大精品爽| 欧美性猛交xxxx| 日本乱人伦a精品| 成人激情电影一区二区| 亚洲欧美自拍一区| 国产乱肥老妇国产一区二| 中文字幕国产精品久久| 国内精品模特av私拍在线观看| 欧美成人精品在线观看| 久久精品国产96久久久香蕉| 97在线看免费观看视频在线观看| 日韩精品久久久久久久玫瑰园| 国产亚洲一区二区在线| 国产精品一区久久久| 亚洲第一国产精品| 欧美激情手机在线视频| 91在线无精精品一区二区| 欧美大片网站在线观看| 国内揄拍国内精品少妇国语| 日韩av片电影专区| 色婷婷综合成人| 欧美日韩中文字幕日韩欧美|