读JS高级关于this对象的理解

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_36070288/article/details/98730871

例子

var name = 'The window'
var object = {
    name: 'My Object',
    getName: function () {
        return this.name
    }
}

object.getName() // 'My Object'
(object.getName)() // 'My Object'
(object.getName = object.getName)() // 'The window'

结果分析

this指向调用函数的对象(也就是点号前面的对象)

  • object.getName()和(object.getName)()都明确指定了函数调用者,所以this指向object;
  • (object.getName=object.getName)()里前面的赋值表达式会返回赋的值也就是函数本身,等同于(function(){return this.name})() ,这里函数没有指定调用者,this指向全局变量window,所以返回window.name

猜你喜欢

转载自blog.csdn.net/qq_36070288/article/details/98730871