前端开发

函数调用相关

2019-01-26  本文已影响0人  李轻舟

var myObject = {

    foo: "bar",

    func: function() {

        var self = this;

        console.log(this.foo); 

        console.log(self.foo); 

        (function() {

            console.log(this.foo); 

            console.log(self.foo); 

        }());

    }

};

myObject.func();

程序的输出是什么?

A. bar bar bar bar

B. bar bar bar undefined

C. bar bar undefined bar

D. undefined bar undefined bar

解析:

依次输出  bar  bar  undefined bar

理解关键:方法/函数是由谁(对象) 调用 的,方法/函数内部的 this 就指向谁(该对象);

注意:被谁调用,不是处于谁的作用域,即使在作用域

1、func是由myObject调用的,this指向 myObject。

2、self指向myObject,相当于 myObject的this的副本。

3、这个立即执行匿名函数表达式(IIFE)是由window调用的,this指向 window 。

4、IIFE的作用域处于myObject.func的作用域中,本作用域找不到self变量,沿着作用域链向上查找self变量,找到了指向 myObject对象的 self。

上一篇下一篇

猜你喜欢

热点阅读