jQuery實(shí)現(xiàn)仿京東防抖動(dòng)菜單效果示例
本文實(shí)例講述了jQuery實(shí)現(xiàn)仿京東防抖動(dòng)菜單效果。分享給大家供大家參考,具體如下:
完整代碼:
<!DOCTYPE html>
<html>
<head>
<title>chabaoo.cn 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>防抖動(dòng)</h2>
<div class="menu">
<ul class="menu_list">
<li class="menu_item"><a href="">熱點(diǎn)要聞</a></li>
<li class="menu_item"><a href="">個(gè)性推薦</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" style="display:none">
<div class="menu_cont_list">
<ul>
<li>
<h3><a href="">618,劉強(qiáng)東笑了,很多人哭了</a></h3>
</li>
<li>
<h3><a href="">普通人如何分享人民幣增值紅利</a></h3>
</li>
<li>
<h3><a href="">大都市里藏板房小學(xué)悶熱無(wú)比 </a></h3>
</li>
</ul>
</div>
<div class="menu_cont_list">
<ul>
<li>
<h3><a href="">中國(guó)煉油產(chǎn)能過(guò)剩超億噸 油價(jià)迫近4元降回到十年前</a></h3>
</li>
<li>
<h3><a href="">銀行大幅上調(diào)首套房貸利率 這些人最受影響</a></h3>
</li>
<li>
<h3><a href="">江南大范圍強(qiáng)降雨再次來(lái)襲 今明北方旱區(qū)多雷陣雨</a></h3>
</li>
</ul>
</div>
<div class="menu_cont_list">
<ul>
<li>
<h3><a href="">京郊特產(chǎn)組團(tuán)進(jìn)超市 類(lèi)似活動(dòng)將在全市推開(kāi)</a></h3>
</li>
<li>
<h3><a href="">北京某高檔小區(qū)地下二層防空洞改群租房</a></h3>
</li>
<li>
<h3><a href="">北京市民踴躍收聽(tīng)收看市黨代會(huì)開(kāi)幕直播</a></h3>
</li>
</ul>
</div>
<div class="menu_cont_list">
<ul>
<li>
<h3><a href="">英國(guó)推出“錢(qián)味香水”:隨時(shí)感受鈔票味兒</a></h3>
</li>
<li>
<h3><a href="">美國(guó)是如何買(mǎi)下阿拉斯加的?為何俄國(guó)悔不當(dāng)初?</a></h3>
</li>
<li>
<h3><a href="">將增近4000人,美國(guó)為何欲大幅增兵阿富汗?</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在線(xiàn)運(yùn)行測(cè)試工具:http://tools.jb51.net/code/HtmlJsRun,可得到如下測(cè)試運(yùn)行效果:

問(wèn)題:鼠標(biāo)第一次移入的時(shí)候是不需要延遲的,所以加入了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();
}
})
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《jQuery切換特效與技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》、《jQuery動(dòng)畫(huà)與特效用法總結(jié)》及《jquery選擇器用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- jquery仿京東導(dǎo)航/仿淘寶商城左側(cè)分類(lèi)導(dǎo)航下拉菜單效果
- jQuery仿京東商城樓梯式導(dǎo)航定位菜單
- jQuery模仿京東/天貓商品左側(cè)分類(lèi)導(dǎo)航菜單效果
- jQuery簡(jiǎn)單實(shí)現(xiàn)仿京東商城的左側(cè)菜單效果代碼
- Jquery實(shí)現(xiàn)仿京東商城省市聯(lián)動(dòng)菜單
- jQuery簡(jiǎn)單實(shí)現(xiàn)仿京東分類(lèi)導(dǎo)航層效果
- jquery仿京東側(cè)邊欄導(dǎo)航效果
- 使用jquery菜單插件HoverTree仿京東無(wú)限級(jí)菜單
- jQuery和CSS仿京東仿淘寶列表導(dǎo)航菜單
- jQuery實(shí)現(xiàn)網(wǎng)頁(yè)抖動(dòng)的菜單抖動(dòng)效果
相關(guān)文章
基于jquery的textarea發(fā)布框限制文字字?jǐn)?shù)輸入(添加中文識(shí)別)
基于jquery的textarea發(fā)布框限制文字字?jǐn)?shù)輸入(添加中文識(shí)別),需要的朋友可以參考下2012-02-02
jquery處理頁(yè)面彈出層查詢(xún)數(shù)據(jù)等待操作實(shí)例
這篇文章主要介紹了jquery處理頁(yè)面彈出層查詢(xún)數(shù)據(jù)等待操作,實(shí)例分析了jquery實(shí)現(xiàn)等待效果的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
一步步教大家編寫(xiě)酷炫的導(dǎo)航欄js+css實(shí)現(xiàn)
一步步教大家編寫(xiě)酷炫的導(dǎo)航欄,js+css實(shí)現(xiàn)黑色經(jīng)典導(dǎo)航欄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03
BootStrap中jQuery插件Carousel實(shí)現(xiàn)輪播廣告效果
輪播廣告在網(wǎng)站中的應(yīng)用實(shí)在是太常見(jiàn)了,下面說(shuō)一說(shuō)怎樣使用bootstrap中的Carousel插件來(lái)實(shí)現(xiàn)輪播廣告效果,感興趣的朋友一起看看吧2017-03-03
基于 jQuery 實(shí)現(xiàn)鍵盤(pán)事件監(jiān)聽(tīng)控件
這篇文章主要介紹了基于 jQuery 的鍵盤(pán)事件監(jiān)聽(tīng)控件,需要的朋友可以參考下2019-04-04
jQuery實(shí)現(xiàn)的滑塊滑動(dòng)導(dǎo)航效果示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的滑塊滑動(dòng)導(dǎo)航效果,涉及jQuery事件響應(yīng)及頁(yè)面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-06-06
淺談MVC+EF easyui dataGrid 動(dòng)態(tài)加載分頁(yè)表格
下面小編就為大家?guī)?lái)一篇淺談MVC+EF easyui dataGrid 動(dòng)態(tài)加載分頁(yè)表格。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11
基于jquery實(shí)現(xiàn)三級(jí)下拉菜單
這篇文章主要為大家詳細(xì)介紹了基于jquery實(shí)現(xiàn)三級(jí)下拉菜單的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05

