欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jQuery实现仿京东防抖动菜单效果示例

程序员文章站 2023-11-06 17:02:16
本文实例讲述了jquery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下: 完整代码:

本文实例讲述了jquery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下:

完整代码:

<!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>
<h2>防抖动</h2>
<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="">环球视野</a></li>
  </ul>
  <div class="menu_cont" style="display:none">
    <div class="menu_cont_list">
      <ul>
        <li>
          <h3><a href="">618,刘强东笑了,很多人哭了</a></h3>
        </li>
        <li>
          <h3><a href="">普通人如何分享人民币增值红利</a></h3>
        </li>
        <li>
          <h3><a href="">大都市里藏板房小学闷热无比 </a></h3>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h3><a href="">中国炼油产能过剩超亿吨 油价迫近4元降回到十年前</a></h3>
        </li>
        <li>
          <h3><a href="">银行大幅上调首套房贷利率 这些人最受影响</a></h3>
        </li>
        <li>
          <h3><a href="">江南大范围强降雨再次来袭 今明北方旱区多雷阵雨</a></h3>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h3><a href="">京郊特产组团进超市 类似活动将在全市推开</a></h3>
        </li>
        <li>
          <h3><a href="">北京某高档小区地下二层防空洞改群租房</a></h3>
        </li>
        <li>
          <h3><a href="">北京市民踊跃收听收看市党代会开幕直播</a></h3>
        </li>
      </ul>
    </div>
    <div class="menu_cont_list">
      <ul>
        <li>
          <h3><a href="">英国推出“钱味香水”:随时感受钞票味儿</a></h3>
        </li>
        <li>
          <h3><a href="">美国是如何买下阿拉斯加的?为何俄国悔不当初?</a></h3>
        </li>
        <li>
          <h3><a href="">将增近4000人,美国为何欲大幅增兵阿富汗?</a></h3>
        </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实现仿京东防抖动菜单效果示例

问题:鼠标第一次移入的时候是不需要延迟的,所以加入了mouseflag

优化后的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();//默认隐藏容器窗口
  $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切换特效与技巧总结》、《jquery扩展技巧总结》、《jquery常用插件及用法总结》、《jquery拖拽特效与技巧总结》、《jquery常见经典特效汇总》、《jquery动画与特效用法总结》及《jquery选择器用法总结

希望本文所述对大家jquery程序设计有所帮助。