关于变量重新申明的一点问题

Posted 无情码字员

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于变量重新申明的一点问题相关的知识,希望对你有一定的参考价值。

var a = 1;

var a;

console.log(a)   //  1

 

这里把a重新申明了一遍,但是并没有给a 重新赋值,所以之前 a 是什么值现在还是什么值

 

问题出处

var foo = {a: 1};

(function(foo){
  var foo;  // 重新定义,但是并未赋值,指向的地址还是外部传入的foo
  console.log(foo.a);  //  1
  foo.a = 3;   // 和外部变量地址一致, 外部的 foo = {a:3}
  foo = {a: 2}  // 重新赋值,变量存储地址改变,  内部变量 foo = {a:2}
  console.log(foo.a)  // 输出函数内部变量 foo.a     2
})(foo)

console.log(foo.a) // 输出外部变量foo的 foo.a  3


//  输出顺序为 1,2,3

 

以上是关于关于变量重新申明的一点问题的主要内容,如果未能解决你的问题,请参考以下文章

关于耦合度的一点反思

关于IDE与环境变量的一点说明

关于闭包的一点理解

自己关于ES6的一点理解

关于JS中变量提升的规则和原理的一点理解

关于面向对象的一点牢骚