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;