首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >$.Callbacks().disable() vs $.Callbacks().lock()

$.Callbacks().disable() vs $.Callbacks().lock()
EN

Stack Overflow用户
提问于 2012-09-04 02:43:05
回答 1查看 1.4K关注 0票数 6

这两者的jQuery文档基本上说明了相同的事情,所以我想知道这两者之间是否有任何主要的区别。谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-04 03:05:34

有关这方面的文档实际上非常糟糕,所以这是我在studying the source code上找到的

只会阻止将来的 调用,但不会阻止函数被

下面是这些方法的简要介绍:

  • -删除因此而注册的任何回调far.
  • -阻止进一步调用added.
  • ,但允许更多回调被add.

-阻止进一步调用firefire

为了理解这一切,让我们从解释the memory flag开始

如果回调对象是用memory标志构造的,它将跟踪最后一次fire调用,并且以后添加的任何回调都将立即被调用。这是an example

代码语言:javascript
复制
var callbacks = $.Callbacks('memory');

callbacks.add(function(){
    console.log('first');
});

callbacks.fire();

callbacks.add(function(){
    console.log('second');
});

这也会记录第二个,即使它是在fire调用之后添加的。

但是,如果你使用disable,它将会完全清除内存。这是another example

代码语言:javascript
复制
var callbacks = $.Callbacks('memory');

callbacks.add(function(){
    console.log('first');
});

callbacks.fire();
callbacks.disable();

callbacks.add(function(){
    console.log('second');
});

callbacks.fire();

这将只记录第一个,因为在添加第二个函数之前,callbacks已经被禁用。

但是,如果您使用lock it,则稍后添加的函数将被调用。这是another example

代码语言:javascript
复制
var callbacks = $.Callbacks('memory');

callbacks.add(function(){
    console.log('first');
});

callbacks.fire();
callbacks.lock();

callbacks.add(function(){
    console.log('second');
});

callbacks.fire();

这也会记录第二个,但只记录一次;因为对象是locked的,所以对fire的任何进一步调用都将被忽略。

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

https://stackoverflow.com/questions/12252709

复制
相关文章

相似问题

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