javascript 如何防止多次触发hover事件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript 如何防止多次触发hover事件相关的知识,希望对你有一定的参考价值。

我用jquery做了一个淡入淡出的幻灯图片切换功能,一共有5张图片,幻灯会自动执行切换,,也可以通过设定的按钮触发hover事件来执行,但遇到一个问题就是,假如我疯狂的用鼠标移入移出按钮,这样hover事件就会触发了多次,倒置最后鼠标离开后,幻灯也再快速的切换,直到之前的hover事件完毕后才正常,,,,我希望有什么办法可以限制hover事件,只触发当前前,,,多余的就清除掉可以吗?
$("#hover_div").unbind("mouseenter").unbind("mouseleave"); 这是一句jquery清除hover的事件,但是一清除是没法再继续的啦。。。。。。。

$(XX).hover(
function()

t = setTimeout(function()
    //要执行的操作;鼠标放上去后200毫秒才执行
,
200);
,
function()
        //鼠标移除后清除上面的操作;
clearTimeout(t);

);
//思路大概是这样,具体看你怎么操作了;

参考技术A 动画事件前加入.stop()方法.

stop()方法有两个参数,你可以全部开启stop(true,true)

意思就是立即让动画进入最后完成阶段,并结束之前所有动画.

ztree在onCheck()方法中防止因触发联动关系导致页面多次渲染而卡死的问题

  这几天在项目中遇到了要使用树形选择框, 而且要求比较复杂,具体叙述如下:

  首先是有个选择框,左边选择是适用的商品,右边显示已经选择的商品.也就是说,左边每次勾选操作,都要触发一个事件去刷新右边的页面, 而且,左边商品如果选择大类,则右边显示大类,其下小类都不显示

也就是说有父子联动的关系. 刚开始的时候, 选择了使用bootStrap的tree_view这个插件,一开始还好,基本成型,后来测试时才发现问题,,当数据量很大的时候,,这个插件用起来很卡很卡,,而且又加了个带搜索功能,这个插件就显得有点鸡肋,这时才发现了ztree.

  ztree虽然没有tree_view界面好看,但是其拥有强大的api,和渲染速度,,比前者好用多了.后面在数据渲染的时候遇到了一个问题,当时设置了父子级关联,然后再oncheck里面刷新右侧的显示界面.刚开始没啥问题,,后面当商品加到8000个的时候,,之前的问题又出现了,当我点击父级的时候,页面直接无响应.打上断点跟着,才发现ztree内部会由于关联关系,多次触发onchek事件,导致页面直接卡死.苦思良久都没得办法..直到无意中看到一个方法

                                                                  技术图片

beforeCheck,对就是这个方法,在oncheck触发之前的回调,,于是我想到了办法

 1 var temp="";
 2     var setting = 
 3         check: 
 4             enable: true,
 5             autoCheckTrigger: true
 6         ,
 7         data: 
 8             simpleData: 
 9                 enable: true
10             
11         ,
12         callback: 
13             onCheck: zTreeOnCheck,
14             beforeCheck: zTreeBeforeCheck
15         
16     ;
17 
18     function zTreeBeforeCheck(treeId, treeNode)
19         temp=treeNode;
20     
21     function zTreeOnCheck(event, treeId, treeNode) 
22     //debugger
23         if(treeNode.name!=temp.name)
24             return;
25         
26         refresh(treeNode);      
27     

用一个temp去存储将要触发oncheck()的节点对象, 然后再在oncheck()方法中判断触发这个方法的是不是你当前所勾选的节点,如果不是就直接pass,这样一来,下面的刷新页面方法就不会因为父子联动而多次触发了,

页面的响应速度也是杠杠的.现在真的发现,ztree真的是个强大的工具,速度快,功能全,有很多你想不到的方法.

最后附上ztree地址:http://www.treejs.cn/v3/api.php

 

以上是关于javascript 如何防止多次触发hover事件的主要内容,如果未能解决你的问题,请参考以下文章

如何防止多次播放动画 - Jquery

如何防止 jQuery 悬停事件在未完成时触发?

防止多次执行 JavaScript 函数

什么可以阻止 CSS :hover 类工作?

如何防止按键重复被触发 - JavaScript/jQuery

防止在 Angular 中多次触发令牌刷新请求