ClearTimeout消除闪动实例代码

前端之家收集整理的这篇文章主要介绍了ClearTimeout消除闪动实例代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

定义和用法

clearTimeout() 方法可取消由 setTimeout() 方法设置的 timeout。

语法

代码块。

需求:当鼠标放到父级菜单上面的时候,显示下方的子菜单。鼠标从子菜单或者父级菜单上面移开的时候,子菜单要收起来。最终效果如下:

PS:这样需求很常见,最常见的做法是li元素下面再嵌套一个Ul元素来包含子元素。这种做法用css就可以完全控制。但今天这个子菜单和导航栏是分开的。即到鼠标到产品上面的时候显示header-tags块。

  • 全部

  • 沙发

  • 座椅

  • ....

    这无法用css完全控制(hover只能控制子元素或兄弟元素)。

    上面的情况就要用脚本了。这里涉及到#header_tags和.header-tags两个元素的移入移出。当鼠标移入#header_tags,.header-tags显示,当鼠标再移入.header-tags的时候不能立即触发#header_tags的moveout事件,而要保持tags继续显示。只有到鼠标从#header_tags和.header-tags离开后没有再进入才会把子菜单收起来。

    SEOver 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); }); });

    如果这里没有清除定时器和加上延时执行,导航栏就会不断的闪动。根本无法点击。

    原文链接:https://www.f2er.com/js/49903.html

    猜你在找的JavaScript相关文章