以下代码的结果是什么?请解释你的答案。
var fullname = 'John Doe'; var obj = { fullname: 'Colin Ihrig', prop: { fullname: 'Aurelio De Rosa', getFullname: function() { return this.fullname; } } }; console.log(obj.prop.getFullname()); var test = obj.prop.getFullname; console.log(test());
答案:
这段代码打印结果是:Aurelio De Rosa
和 John Doe
。原因是,JavaScript中关键字this
所引用的是函数上下文,取决于函数是如何调用的,而不是怎么被定义的。
在第一个console.log()
,getFullname()
是作为obj.prop
对象的函数被调用。因此,当前的上下文指代后者,并且函数返回这个对象的fullname
属性。相反,当getFullname()
被赋值给test
变量时,当前的上下文是全局对象window
,这是因为test
被隐式地作为全局对象的属性。基于这一点,函数返回window
的fullname
,在本例中即为第一行代码设置的。