Javascript 为什么在这种情况下超时变量是可共享的?

Javascript 为什么在这种情况下超时变量是可共享的?,javascript,scope,closures,settimeout,debouncing,Javascript,Scope,Closures,Settimeout,Debouncing,在文章中,有人明智地指出 timeout变量在每次调用 产生的函数,即使在去抖动本身已返回后,也可以 换不同的电话 这对我来说没什么意义。由于timeout变量是每个debounce调用的本地变量,因此它不应该是可共享的,不是吗 p、 即使是闭包,每个调用都应该有不同的闭包,它们只是在母函数返回后同时延长它们的生命,但它们不应该互相交谈,对吗 下面是另一个问题的函数: // Returns a function, that, as long as it continues to be invok

在文章中,有人明智地指出

timeout变量在每次调用 产生的函数,即使在去抖动本身已返回后,也可以 换不同的电话

这对我来说没什么意义。由于timeout变量是每个debounce调用的本地变量,因此它不应该是可共享的,不是吗

p、 即使是闭包,每个调用都应该有不同的闭包,它们只是在母函数返回后同时延长它们的生命,但它们不应该互相交谈,对吗

下面是另一个问题的函数:

// Returns a function, that, as long as it continues to be invoked, will not
// be triggered. The function will be called after it stops being called for
// N milliseconds.
function debounce(func, wait, immediate) {
    var timeout;              //Why is this set to nothing?
    return function() {
        var context = this, 
        args = arguments;
        clearTimeout(timeout);   // If timeout was just set to nothing, what can be cleared? 
        timeout = setTimeout(function() {
             timeout = null;
             if (!immediate) func.apply(context, args);
        }, wait);
        if (immediate && !timeout) func.apply(context, args);  //This applies the original function to the context and to these arguments?
     }; 
};

是的,每次调用
debounce
都会得到一组新的内容,但您不会重复调用
debounce
。您正在调用一次
debounce
,然后重复调用从
debounce
返回的函数。该函数在超时后关闭

var f = debounce(func, wait, immediate);
f();  // won't call func immediately
f();  // still won't call func 
// wait a while, now func will be called

您只需多次调用
debounce
本身来设置多个去Bounce函数(在上面的示例中是a
g
h

是的,每次调用
debounce
都会得到一组新的内容,但您不会重复调用
debounce
。您正在调用一次
debounce
,然后重复调用从
debounce
返回的函数。该函数在超时后关闭

var f = debounce(func, wait, immediate);
f();  // won't call func immediately
f();  // still won't call func 
// wait a while, now func will be called

您只需多次调用
debounce
自身来设置多个去抖动函数(在上面的示例中是a
g
h

是否实际使用了“上下文”变量?在我的调试测试中,“context”变量总是指窗口对象。我想这是因为它是一个匿名函数。它还有其他用途吗?谢谢。我想您可以将返回的闭包分配给一个对象,该对象将成为原始
func
中的
this
var x={f:debounce(func,w,I)};x、 f();}
或在调用
f
时提供它:
f.apply(需要成为thisinfunc的某些对象)
。因此,如果
func
是一个“方法”而不仅仅是一个裸函数,那么这很有用。“上下文”变量有实际用途吗?在我的调试测试中,“context”变量总是指窗口对象。我想这是因为它是一个匿名函数。它还有其他用途吗?谢谢。我想您可以将返回的闭包分配给一个对象,该对象将成为原始
func
中的
this
var x={f:debounce(func,w,I)};x、 f();}
或在调用
f
时只提供它:
f.apply(需要成为此函数的某些对象)
。因此,如果
func
是一个“方法”,而不仅仅是一个空函数,那么这将非常有用。