首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >.bind()和.unbind()不能正常工作

.bind()和.unbind()不能正常工作
EN

Stack Overflow用户
提问于 2013-02-10 20:57:59
回答 1查看 372关注 0票数 1

我有两个链接,如果用户单击其中一个,与链接相关的文章将显示在animation.if中--用户单击第一个链接后单击另一个链接,而在上一个动画完成之前,他们的动画将发生冲突。我希望使用.bind().unbind()函数来防止用户单击链接,而其他链接的事件是working.but,当我取消绑定事件时,它不会在动画后绑定到元素。

JS代码:

代码语言:javascript
复制
$("a[href='#about-enamel']").click(function () {
        $("a[href!='#about-enamel']").unbind("click");
        if ($("article[id='about-enamel']").attr('class') === 'visible') {
            $("a[href!='#about-enamel']").bind("click");
            return 0;
        }
        else if ($("article[class='visible']").length) {
            $("article[class='visible']").hide('drop', { easing: 'easeOutBack', direction: 'down' }, 500, function () {
                $(this).attr('class', 'hidden');
                $("article[id='about-enamel']").show('drop', { easing: 'easeInBack', direction: 'up' }, 500, function () {
                    $(this).attr('class', 'visible');
                    $("a[href!='#about-enamel']").bind("click");
                });
            });
        }
        else {
            $("article[id='about-enamel']").show('drop', { easing: 'easeInBack', direction: 'up' }, 500, function () {
                $(this).attr('class', 'visible');
                $("a[href!='#about-enamel']").bind("click");
            });
        }
    });
    $("a[href='#order']").click(function () {
        $("a[href!='#order']").unbind("click");
        if ($("article[id='order']").attr('class') === 'visible') {
            $("a[href!='#order']").bind("click");
            return 0;
        }
        else if ($("article[class='visible']").length) {
            $("article[class='visible']").hide('drop', { easing: 'easeOutBack', direction: 'down' }, 500, function () {
                $(this).attr('class', 'hidden');
                $("article[id='order']").show('drop', { easing: 'easeInBack', direction: 'up' }, 500, function () {
                    $(this).attr('class', 'visible');
                    $("a[href!='#order']").bind("click");
                });
            });
        }
        else {

            $("article[id='order']").show('drop', { easing: 'easeInBack', direction: 'up' }, 500, function () {
                $(this).attr('class', 'visible');
                $("a[href!='#order']").bind("click");
            });
        }
    });

如果这个问题有其他的解决办法,请通知我。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-02-10 22:28:46

下面是一个基本的示例,说明如何使用stop()来杀死任何正在进行的动画,这样您就可以启动另一个动画,而不会发生冲突。

http://jsfiddle.net/zFAY9/3/

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14802511

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档