这两者的jQuery文档基本上说明了相同的事情,所以我想知道这两者之间是否有任何主要的区别。谢谢!
发布于 2012-09-04 03:05:34
有关这方面的文档实际上非常糟糕,所以这是我在studying the source code上找到的
只会阻止将来的 调用,但不会阻止函数被
下面是这些方法的简要介绍:
added.add. -阻止进一步调用fire和fire
为了理解这一切,让我们从解释the memory flag开始
如果回调对象是用memory标志构造的,它将跟踪最后一次fire调用,并且以后添加的任何回调都将立即被调用。这是an example
var callbacks = $.Callbacks('memory');
callbacks.add(function(){
console.log('first');
});
callbacks.fire();
callbacks.add(function(){
console.log('second');
});这也会记录第二个,即使它是在fire调用之后添加的。
但是,如果你使用disable,它将会完全清除内存。这是another example
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
var callbacks = $.Callbacks('memory');
callbacks.add(function(){
console.log('first');
});
callbacks.fire();
callbacks.lock();
callbacks.add(function(){
console.log('second');
});
callbacks.fire();这也会记录第二个,但只记录一次;因为对象是locked的,所以对fire的任何进一步调用都将被忽略。
https://stackoverflow.com/questions/12252709
复制相似问题