首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >回调函数

回调函数
EN

Stack Overflow用户
提问于 2010-09-04 13:16:14
回答 2查看 667关注 0票数 4

Man我正在尝试理解回调函数。我已经看过很多文章和帖子了。这些解释似乎是循环的,我认为我实际上离理解哈哈越来越远了。我显然在javascript事件中使用过它们,但它更像是“记住这些行”,而不是“这就是发生了什么和为什么”之类的理解。

这就是我的理解。

假设你有两个对象,函数p()和函数k()。将函数k传递给p()。p()然后可以访问k的内部变量。

代码语言:javascript
复制
function p(x){
    alert(x.n);//5
}

function k(){
    this.n = 5;
}

p(k);

尴尬的是,我花了这么长时间才弄到这个。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-09-04 15:19:25

也许举个例子会有所帮助?

代码语言:javascript
复制
// First, lets declare the function we're going to call
calledFunction = function (callback, arg) {
    callback(arg);
};
// Second, lets declare the callback function
callbackFunction = function (arg) {
    alert(arg);
};
// Next, lets do a function call!
calledFunction(callbackFunction, "HAI");

所以,calledFunction()callback参数是callbackFunction,但是,如果你注意到,我们还没有调用这个函数,我们传递了一个包含函数的变量,它的arg函数只是alert()的一部分,当calledFunction()被执行时,它接受作为callback参数传递的任何东西,并以arg作为第一个也是唯一一个参数来调用它。

有帮助吗?

编辑:如果您使用function foo() {}-style声明,它仍然有效。(以防万一;我不知道您对JavaScript的流利程度)

票数 4
EN

Stack Overflow用户

发布于 2010-09-04 13:30:51

你做错了。k()中的this.n = 5;没有设置它的“内部变量”,并且x.n访问function对象的x属性,而不是它的内部变量。试试这个:

function p(x) { alert(new x().n); }

变量绑定是一个重要的编程概念。

我认为这篇文章会有所帮助。http://www.hunlock.com/blogs/Functional_Javascript

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

https://stackoverflow.com/questions/3641009

复制
相关文章

相似问题

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