溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

jQuery如何實現(xiàn)仿京東防抖動菜單效果

發(fā)布時間:2021-05-24 14:41:37 來源:億速云 閱讀:140 作者:小新 欄目:web開發(fā)

小編給大家分享一下jQuery如何實現(xiàn)仿京東防抖動菜單效果,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

本文實例講述了jQuery實現(xiàn)仿京東防抖動菜單效果。分享給大家供大家參考,具體如下:

完整代碼:

<!DOCTYPE html>
<html>
<head>
<title>www.jb51.net jQuery仿京東菜單</title>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<style type="text/css">
*{
  padding: 0;
  margin: 0;
}
li{
  list-style: none;
}
a{
  color:#555;
}
.menu{
  width: 220px;
  border: 2px solid #333;
  position: relative;
}
.menu_item{
  height: 47px;
  padding-left:20px;
  line-height: 47px;
  background-color:#feebf3;
  border-bottom: 1px solid #f0bfd3;
}
.menu_item.current{
  background-color: #fff;
}
.menu_cont{
  position: absolute;
  width: 500px;
  height: 150px;
  top: 0;
  left: 220px;
  padding: 15px;
  border: 1px solid #666;
}
</style>
</head>
<body>
<h3>防抖動</h3>
<div class="menu">
  <ul class="menu_list">
    <li class="menu_item"><a href="">熱點要聞</a></li>
    <li class="menu_item"><a href="">個性推薦</a></li>
    <li class="menu_item"><a href="">北京新聞</a></li>
    <li class="menu_item"><a href="">環(huán)球視野</a></li>
  </ul>
  <div class="menu_cont" >
    <div class="menu_cont_list">
      <ul>
        <li>
          <h4><a href="">618,劉強東笑了,很多人哭了</a></h4>
        </li>
        <li>
          <h4><a href="">普通人如何分享人民幣增值紅利</a></h4>
        </li>
        <li>
          <h4><a href="">大都市里藏板房小學(xué)悶熱無比 </a></h4>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h4><a href="">中國煉油產(chǎn)能過剩超億噸 油價迫近4元降回到十年前</a></h4>
        </li>
        <li>
          <h4><a href="">銀行大幅上調(diào)首套房貸利率 這些人最受影響</a></h4>
        </li>
        <li>
          <h4><a href="">江南大范圍強降雨再次來襲 今明北方旱區(qū)多雷陣雨</a></h4>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h4><a href="">京郊特產(chǎn)組團進超市 類似活動將在全市推開</a></h4>
        </li>
        <li>
          <h4><a href="">北京某高檔小區(qū)地下二層防空洞改群租房</a></h4>
        </li>
        <li>
          <h4><a href="">北京市民踴躍收聽收看市黨代會開幕直播</a></h4>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h4><a href="">英國推出“錢味香水”:隨時感受鈔票味兒</a></h4>
        </li>
        <li>
          <h4><a href="">美國是如何買下阿拉斯加的?為何俄國悔不當(dāng)初?</a></h4>
        </li>
        <li>
          <h4><a href="">將增近4000人,美國為何欲大幅增兵阿富汗?</a></h4>
        </li>
      </ul>
    </div>
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){
  var $menu = $(".menu");
  var $menuItem = $(".menu_item");
  var $menuCont = $(".menu_cont");
  var $menuContList= $(".menu_cont_list")
  var menuTimer;
  $menuItem.on("mouseenter", function(){
    var self = $(this);
    menuTimer = setTimeout(function(){
      self.addClass("current");
      self.siblings().removeClass("current");
      $menuCont.show();
      var _index = self.index();
      $menuContList.eq(_index).show();
      $menuContList.eq(_index).siblings().hide();
    },500)
  }).on("mouseleave", function(){
    if(menuTimer){
      clearTimeout(menuTimer);
    }
  })
  $menu.on("mouseleave", function(){
    $menuCont.hide();
  })
})
</script>
</body>
</html>

使用本站HTML/CSS/JS在線運行測試工具:http://tools.jb51.net/code/HtmlJsRun,可得到如下測試運行效果:

jQuery如何實現(xiàn)仿京東防抖動菜單效果

問題:鼠標(biāo)第一次移入的時候是不需要延遲的,所以加入了mouseFlag

優(yōu)化后的JS為

$(function(){
  var _catTimer;
  var _mouseflag;
  var $menu = $("#menu");
  var $menuItem = $menu.find(".menu_list").children("li");//菜單
  var $menuCont = $menu.find(".menu_cont");//容器
  var $menuContItem = $menuCont.children("div");//
  $menuCont.hide();//默認(rèn)隱藏容器窗口
  $menuItem.on("mouseenter", function(){
    var self = $(this);
    if(!_mouseflag){
      showCont(self);
      _mouseflag = true;
    }else{
      _catTimer = setTimeout(function(){
        showCont(self)
      },300)
    }
  }).on("mouseleave", function(){
    if(_catTimer){
      clearTimeout(_catTimer);
    }
  })
  $menu.on("mouseleave",function(){
    $menuCont.hide();
    $menuItem.removeClass("current");
  })
  var showCont = function (self) {
    self.addClass("current");
    self.siblings().removeClass("current");
    $menuCont.show();//顯示容器窗口
    var _index = self.index();//獲取位置
    $menuContItem.eq(_index).show();
    $menuContItem.eq(_index).siblings().hide();
  }
})

jquery是什么

jquery是一個簡潔而快速的JavaScript庫,它具有獨特的鏈?zhǔn)秸Z法和短小清晰的多功能接口、高效靈活的css選擇器,并且可對CSS選擇器進行擴展、擁有便捷的插件擴展機制和豐富的插件,是繼Prototype之后又一個優(yōu)秀的JavaScript代碼庫,能夠用于簡化事件處理、HTML文檔遍歷、Ajax交互和動畫,以便快速開發(fā)網(wǎng)站。

以上是“jQuery如何實現(xiàn)仿京東防抖動菜單效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI