最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:11:57
文档

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

jQuery实现仿京东防抖动菜单效果示例:本文实例讲述了jQuery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下: 完整代码: <!DOCTYPE html> <html> <head> <title>www.gxlcms.com jQuery仿京东菜单</title> <met
推荐度:
导读jQuery实现仿京东防抖动菜单效果示例:本文实例讲述了jQuery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下: 完整代码: <!DOCTYPE html> <html> <head> <title>www.gxlcms.com jQuery仿京东菜单</title> <met


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

完整代码:

<!DOCTYPE html>
<html>
<head>
<title>www.gxlcms.com 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,可得到如下测试运行效果:

问题:鼠标第一次移入的时候是不需要延迟的,所以加入了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程序设计有所帮助。

文档

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

jQuery实现仿京东防抖动菜单效果示例:本文实例讲述了jQuery实现仿京东防抖动菜单效果。分享给大家供大家参考,具体如下: 完整代码: <!DOCTYPE html> <html> <head> <title>www.gxlcms.com jQuery仿京东菜单</title> <met
推荐度:
标签: 京东 菜单 特效
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top