ClearTimeout消除閃動(dòng)實(shí)例代碼
定義和用法
clearTimeout() 方法可取消由 setTimeout() 方法設(shè)置的 timeout。
語法
clearTimeout(id_of_settimeout)
| 參數(shù) | 描述 |
|---|---|
| id_of_settimeout | 由 setTimeout() 返回的 ID 值。該值標(biāo)識(shí)要取消的延遲執(zhí)行代碼塊。 |
需求:當(dāng)鼠標(biāo)放到父級(jí)菜單上面的時(shí)候,顯示下方的子菜單。鼠標(biāo)從子菜單或者父級(jí)菜單上面移開的時(shí)候,子菜單要收起來。最終效果如下:

PS:這樣需求很常見,最常見的做法是li元素下面再嵌套一個(gè)Ul元素來包含子元素。這種做法用css就可以完全控制。但今天這個(gè)子菜單和導(dǎo)航欄是分開的。即到鼠標(biāo)到產(chǎn)品上面的時(shí)候顯示header-tags塊。
<ul class="header-nav">
<li class="nav-item home"><a href="@Url.Action("Index", "Home")">首頁</a></li>
<li class="nav-item products" id="header_tags">
<a href="#">產(chǎn)品<span class="icon-caret-down"></span></a>
....
</li>
</ul>
<div class="header-tags">
<ul>
<li>
<img class="screening-img-normal" src="~/Content/static/all.png">
<img class="screening-img-hover" src="~/Content/static/all1.png">
<p>全部</p>
</li>
<li tagid="4">
<img class="screening-img-normal" src="~/Content/static/shafa.png">
<img class="screening-img-hover" src="~/Content/static/shafa1.png">
<p>沙發(fā)</p>
</li>
<li tagid="3">
<img class="screening-img-normal" src="~/Content/static/zuoyi.png">
<img class="screening-img-hover" src="~/Content/static/zuoyi1.png">
<p>座椅</p>
</li>
....
</div>
這無法用css完全控制(hover只能控制子元素或兄弟元素)。
/*父子*/
#a:hover #b{display: block}
/*兄弟*/
#a:hover + #b{display: block}
上面的情況就要用腳本了。這里涉及到#header_tags和.header-tags兩個(gè)元素的移入移出。當(dāng)鼠標(biāo)移入#header_tags,.header-tags顯示,當(dāng)鼠標(biāo)再移入.header-tags的時(shí)候不能立即觸發(fā)#header_tags的moveout事件,而要保持tags繼續(xù)顯示。只有到鼠標(biāo)從#header_tags和.header-tags離開后沒有再進(jìn)入才會(huì)把子菜單收起來。
$(function () {
var tagsTime;
$(document).on('mouseover mouseout', '#header_tags', function(event){
var $headerTagsBox = $('.header-tags');
if (event.type == 'mouseover') {
clearTimeout(tagsTime);
$headerTagsBox.slideDown(300);
}
else if (event.type == 'mouseout') {
tagsTime = setTimeout(function(){
$headerTagsBox.slideUp(200);
}, 200);
}
});
$('.header-tags').hover(function(){
clearTimeout(tagsTime);
},function(){
var $me = $(this);
tagsTime = setTimeout(function(){
$me.slideUp(200);
}, 200);
}); });
如果這里沒有清除定時(shí)器和加上延時(shí)執(zhí)行,導(dǎo)航欄就會(huì)不斷的閃動(dòng)。根本無法點(diǎn)擊。
相關(guān)文章
修改 bootstrap table 默認(rèn)detailRow樣式的實(shí)例代碼
這篇文章主要介紹了修改 bootstrap table 默認(rèn)detailRow樣式的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-07-07
ECharts異步加載數(shù)據(jù)與數(shù)據(jù)集(dataset)
這篇文章介紹了ECharts異步加載數(shù)據(jù)與數(shù)據(jù)集(dataset),文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
Javascript實(shí)現(xiàn)hashcode函數(shù)實(shí)現(xiàn)對(duì)象比較與原理說明
在JavaScript中,數(shù)值的比較是比較簡單的,使用相等(==)和全等(===)符號(hào)基本上可以解決大多數(shù)非對(duì)象的比較。但是相等(==)和全等(===)符號(hào)在對(duì)象 object 的比較上,就不能滿足所有的要求了2023-06-06
詳解如何替換項(xiàng)目中的if-else和switch
這篇文章主要為大家介紹了詳解如何替換項(xiàng)目中的if-else和switch,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
JavaScript數(shù)組的定義及數(shù)字操作技巧
這篇文章主要介紹了JavaScript數(shù)組的定義及數(shù)字操作技巧的相關(guān)資料,需要的朋友可以參考下2016-06-06
uni-app?微信小程序授權(quán)登錄的實(shí)現(xiàn)步驟
本文主要介紹了uni-app?微信小程序授權(quán)登錄的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
兩個(gè)JS之間的函數(shù)互相調(diào)用方式
這篇文章主要介紹了兩個(gè)JS之間的函數(shù)互相調(diào)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03

