js作用域综合练习

      function Foo() {
       
        getName = function () {
          console.log(1);
        };
        return this;
      }
      Foo.getName = function () {
        console.log(2);
      };
      Foo.prototype.getName = function () {
        console.log(3);
      };
      var getName = function () {
        console.log(4);
      };
      function getName() {
        console.log(5);
      }

      Foo.getName(); 
      getName();
      Foo().getName(); 
      getName(); 
      new Foo().getName();

解析: 

    function Foo() {
        //注意这个是全局的window.getName,如果this.getName就是函数内的
        getName = function () {
          console.log(1);
        };
        return this;
      }
      Foo.getName = function () {
        console.log(2);
      };
      Foo.prototype.getName = function () {
        console.log(3);
      };
      var getName = function () {
        console.log(4);
      };
      function getName() {
        console.log(5);
      }

      Foo.getName(); //先找构造函数的  2
      getName(); //要注意Foo()我们没有调用,所以指向下面的getName,由于声明变量>声明普通函数所以输出4
      Foo().getName(); //Foo()返回的是Window,window.getName也就是Foo()里的getName
      //有人就会有疑问 但是后面的代码
      // var getName = function () {
      //   console.log(4);
      // };
      // 明明覆盖了Foo()里的getName,别忘了
      //Foo().getName()其实相当于执行了
      /*
      window.getName = function () {console.log(1);};
      所以反而是覆盖了var getName = function () { console.log(4); };
      */
      getName(); //还是后者覆盖前者 window.getName = function () {console.log(1);} 结果是1
      new Foo().getName(); //根据对象的查找机制 先去当前实例对象中找 找不到就去构造函数去找 但是别被构造函数里的getName引诱了
      //那个是window.getName()不是this.getName()所以我们要去实例对象的对象原型(__proto__)去找也没有 最后在构造函数的原型对象中找到了3
      /*
      Foo.prototype.getName = function () {
        console.log(3);
      };
      */
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值