从全局范围内的另一个函数 - Javascript 调用函数构造函数的方法
Calling a method of a function constructor from another function in the global scope - Javascript
>我有以下函数构造函数
function myClass(funcList) {
this.markDone = function() {
console.log("Done");
}
this.execute = function() {
funcList.forEach(function(func){
func.apply(this);
});
}
}
我在全球范围内有几个功能
function func1() {
console.log("func 1");
}
function func2() {
console.log("func 2");
}
var arr = [func1,func2];
我可以这样从类的上下文中调用这些函数
var ob = new myClass(arr);
ob.execute(); //this does work
如何从这些函数 func1 和 func2.
调用 markDone如果我的函数 1 是
function func1() {
console.log("func 1");
markDone();
}
同样适用于 func 2
这行不通。不应该适用于这个照顾上下文吗?
关闭。
- 您需要致电
this.markDone();
-
this
在forEach
循环中设置不同,因此您需要显式设置它或更早地捕获它并将其设置为其他内容,例如that
试试这个:
function func1() {
console.log("func 1");
this.markDone();
}
和:
this.execute = function() {
var that = this;
funcList.forEach(function(func){
func.apply(that);
});
}
这是一个小提琴 http://jsfiddle.net/8649hu9s/1/
你可以这样做
function myClass(funcList) {
var myClass = this;
this.markDone = function() {
console.log("Done");
}
this.execute = function() {
funcList.forEach(function(func){
func.apply(myClass);
});
}
}
function func1() {
console.log("func 1");
this.markDone();
}
function func2() {
console.log("func 2");
}
var arr = [func1,func2];
var ob = new myClass(arr);
ob.execute();
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用