JavaScript不在数组中定义方法
我有以下情况:JavaScript不在数组中定义方法,javascript,Javascript,我有以下情况: var a = { b: function() { alert('hi'); }, c: [{m: this.b}] }; alert(typeof a.c[0].m); 输出为“未定义”。原因是什么?因为您在对象中使用了这个关键字。在这种情况下,这个.b指的是未定义的内容,它应该是窗口的属性 请阅读,了解作用域是非常有用的 在这种情况下,您应该这样声明变量: b = 't'; //note there is not keywork v
var a = {
b: function() {
alert('hi');
},
c: [{m: this.b}]
};
alert(typeof a.c[0].m);
输出为“未定义”。原因是什么?因为您在对象中使用了
这个
关键字。在这种情况下,这个.b
指的是未定义的内容,它应该是窗口的属性
请阅读,了解作用域是非常有用的
在这种情况下,您应该这样声明变量:
b = 't'; //note there is not keywork var, it is a window global variable
var a = {
c: [{
b: 'a',
m: this.b //is 't'
}],
b: function() {
alert('hi');
}
};
alert(a.c[0].m); //will display 't'
因为您正在对象中使用这个
关键字。在这种情况下,这个.b
指的是未定义的内容,它应该是窗口的属性
请阅读,了解作用域是非常有用的
在这种情况下,您应该这样声明变量:
b = 't'; //note there is not keywork var, it is a window global variable
var a = {
c: [{
b: 'a',
m: this.b //is 't'
}],
b: function() {
alert('hi');
}
};
alert(a.c[0].m); //will display 't'
因为(假设您在浏览器的上下文中执行此操作)此
是窗口
,并且您尚未定义窗口.b
此
的值由您执行当前函数的方式决定,而不是由对象文字决定
MDN有.因为(假设您是在浏览器上下文中执行此操作)此
是窗口
,而您尚未定义窗口.b
此
的值由您执行当前函数的方式决定,而不是由对象文字决定
MDN有。当运行a.c[0].m的值时,这不是指a,而是指整个范围
如果您想了解您所追求的行为,您需要将其更改为:
var a = { b: function() { alert('hi'); }, c: [{}] };
a.c[0].m = a.b;
当运行a.c[0].m的值时,这不是指a,而是指整个范围
如果您想了解您所追求的行为,您需要将其更改为:
var a = { b: function() { alert('hi'); }, c: [{}] };
a.c[0].m = a.b;