仿京东防抖动菜单

完整代码:

<!DOCTYPE html>
<html>
<head>
	<title></title>
	<meta charset="utf-8">
	<script src="http://www.jq22.com/jquery/jquery-2.1.1.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>

问题:鼠标第一次移入的时候是不需要延迟的,所以加入了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();
	}

})



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值