jquery动画累积执行解决方法

刚学JavaScript和jQuery时,我经常会遇到click hover mouseover等事件多次触发由于有延迟会导致你“触发的累计”就是你不想触发了,事件还在执行,动画的累积执行使得用户的体验很不好,下面累计了碰到的问题及想到的解决方法

实例如下

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>使用show()和hide()方法显示和隐藏元素</title>
    <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" type="text/javascript"></script>
    <style type="text/css" >
        div
{
margin: 10px 0px;
border: solid 1px #ccc;
width: 280px;
}
ul
{
list-style-type: none;
padding: 5px;
margin: 0px;
display: none;
}
li
{
margin: 3px;
}
h4
{
background-color: #eee;
padding: 5px;
margin: 0px;
}
    </style>

</head>

<body>
    <h3>使用show()和hide()方法显示和隐藏元素</h3>
    <div>
        <h4 id="h4">我喜欢吃的水果</h4>
        <ul>
            <li>苹果</li>
            <li>甘桔</li>
            <li>梨</li>
        </ul>
        <input id="hidval" type="hidden" value="0"/>
    </div>

    <script type="text/javascript">
        $(function () {
            $("h4").bind("click", function () {
                if ($("#hidval").val() == 0) {
                    $("ul").show(500);
                    $("#hidval").val(1);
                } else {
                    $("ul").hide(500);
                    $("#hidval").val(0);
                }
            });
        });
    </script>
</body>
</html>

1.使用一个 变量 来存储当前的状态,将设置哨兵变量的代码段放在hide和show函数的回调函数中

$(function () {
            $("h4").bind("click", function () {
                if ($("#hidval").val() == 0) {
                    $("ul").show(500,function(){
                        $("#hidval").val(1);
                    });

                } else {
                    $("ul").hide(500,function(){
                        $("#hidval").val(0);
                    });

                }
            });
        });

2.可以使用setTimeout函数来设置hover,当鼠标滑上目标时设置一个延迟,然后再移除的时候清楚掉,利用的就是当你设置的事件还没有开始执行的时候就把之前的事件给清楚掉了(能解决,但不是很完善)

   <script type="text/javascript">
        $(function(){
            var t = null;
            $("h4").hover(function(){
                t =setTimeout(function(){
                    $("ul").show(300)
                },200)
            },function(){
                clearTimeout(t)
                $("ul").hide(300)
            })
        })
    </script>

3.使用filter(‘:not(:animated)’),这里先过滤掉正在执行的动画

<script type="text/javascript">
    $(function(){
            $("h4").hover(function(){
                $("ul").filter(':not(:animated)').show(300);
            },function(){
                $("ul").hide(300);
            })
        })
</script>

4.使用stop(true,true)函数(这个感觉也是不太好,相比之下filter好点),基本就是每次进入新的动画前,结束掉之前的动画。

stop()的用法为
$("#div").stop();//停止当前动画,继续下一个动画
$("#div").stop(true);//清除元素的所有动画
$("#div").stop(false, true);//让当前动画直接到达末状态 ,继续下一个动画
$("#div").stop(true, true);//清除元素的所有动画,让当前动画直接到达末状态
--------------------- 

作者:wenlong_date
原文:https://blog.csdn.net/ntoskiking/article/details/51090642
版权声明:本文为博主原创文章,转载请附上博文链接!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,193评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,306评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,130评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,110评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,118评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,085评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,007评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,844评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,283评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,508评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,395评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,985评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,630评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,797评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,653评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,553评论 2 352

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明先生_X自主阅读 15,979评论 3 119
  • 初冬之晨 天刚蒙蒙亮, 风声起, 我从睡梦中醒来, 不远公园的树林里, 一只不知名的鸟儿打开清脆的喉咙开始歌唱, ...
    ShiYuan_8b22阅读 238评论 0 0
  • 一位毕业两年的年轻人,他对未来很迷茫、焦虑,不清楚自己可以做什么,想做什么,于是画了这样一幅画。 作画顺序:房,路...
    墨小菲阅读 628评论 0 1
  • 1、持久化引起的主线程阻塞操作:fork阻塞、AOF刷盘阻塞、HugePage写操作阻塞 2、
    SkTj阅读 282评论 0 1
  • 我养了一只小乌龟,它有一个硬硬的壳,还有一个长长的脖子但是脑袋不大,它的四个小爪子很锋利,它每天在鱼缸里慢悠悠的游...
    郭亚慧阅读 204评论 0 1