从另一个作用域调用函数
Calling function from another scope
我在javascript中有以下函数:
function jsController() {
this.foo = function() {
$("body").click(function() {
$(this).externalFunction();
}
};
this.externalFunction = function() {
alert('a');
};
}
但是它不起作用,它说externalFunction()是未定义的。
我该如何解决这个问题?
在本例中:$(this).externalFunction()
this
对象的作用域为$("body")
元素。解决方法:
function jsController() {
var self = this;
this.foo = function() {
$("body").click(function() {
self.externalFunction();
}
};
this.externalFunction = function() {
alert('a');
};
}
您可以轻松使用.bind()
来解决此问题:
function jsController() {
this.foo = function() {
$("body").click(function() {
this.externalFunction();
}.bind(this))
};
this.externalFunction = function() {
alert('a');
};
}
甚至像这样:
function jsController() {
this.foo = function() {
$("body").click(this.externalFunction.bind(this))
};
this.externalFunction = function() {
alert('a');
};
}
看到:bind
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用