js 保留字name 导致的误解

今天刷到一道题:

  function Foo(){    
       this.name="test1";    // 这里 this 指向实例对象
       function bar(){        
           this.name="test2";  // this 指向 window
       };    
       bar(); 
  }   
  Foo.name="test3"; 
  var foo = new Foo();
  console.log(Foo);   // 输出函数
  console.log(Foo.name); // Foo
  console.log(foo.name); // test1

原以为 倒数第二行输出 "test3" 妥妥没问题的,然而谁想到输出的是 Foo

后来一查

name 还是个属性名,因此上式的Foo.name 就是指Foo 函数的名称,因此就是 “Foo”

但是这里又想了,既然说 Foo.name ='test3',那可不可以算是 给 Foo  换一个函数名,叫"test3",然后测试发现

function Foo(){    
     this.name="test1";   
     function bar(){        
        this.name="test2";
     };    
     bar(); 
}   
Foo.name="test3"; 
var foo = new Foo();
console.log(Foo);   // 输出函数
console.log(test3.name); // test3 未定义
console.log(foo.name); // test1

想法是错的,看来我可能有点钻牛角尖了。

所以最后的结论就是,函数名.name == 函数名,而且不能被改变 /  重新赋值

然后还看到有相同的测试结果

https://www.cnblogs.com/yaoxiaowen/p/6838818.html?utm_source=itdadao&utm_medium=referral

所以最后的结论就是,命名的时候尽量不要用 name 、value 等作为变量名

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值