美文网首页
变量声明提升和隐式变量声明

变量声明提升和隐式变量声明

作者: 零穆 | 来源:发表于2020-07-14 15:07 被阅读0次

变量声明提升原理

  引擎会在解释 JavaScript代码之前首先对其进行编译。编译阶段中的一部分工作就是找到所有的声明,并用合适的作用域将它们关联起来,这也正是词法作用域的核心内容。因此包括变量和函数在内的所有声明都会在任何代码被执行前首先被处理,这也正是变量声明提升。
  如var a = 1,可能会认为这是一个声明。但JavaScript实际上会将其看成两个声 明:var a;a = 2;。第一个定义声明是在编译阶段进行的。第二个赋值声明会被留在原地等待执行阶段。

function foo(){
  a = 2;
  var a; 
  console.log( a );//2
}
function foo1(){
  console.log( a );//undefined
  var a = 2;
}
foo1()
foo()

  他们等价于=>

function foo(){
  var a; 
  a = 2;
  console.log( a );//2
}
function foo1(){
  var a
  console.log( a );//undefined
  a  = 2;
}
foo1()
foo()

函数优先

  函数声明和变量声明都会被提升。但是一个值得注意的细节(这个细节可以出现在有多个“重复”声明的代码中)是函数会首先被提升,然后才是变量。

foo(); // 1 
var foo; 
function foo() { 
  console.log( 1 );
}
foo = function() { 
  console.log( 2 ); 
}; 

会输出1而不是2!这个代码片段会被引擎理解为如下形式:

function foo() { 
  console.log( 1 ); 
}
foo(); // 1 
foo = function() { 
  console.log( 2 ); 
};

其中阔以看到函数声明会提升,函数表达式不会。

值得注意的事

  var变量声明和函数声明会提升,但是在es6语法中。let和const不会被提升。

console.log(c) //ReferenceError: Cannot access 'c' before initialization
let c = 3;

隐式函数声明

function foo (){
  a = "1"
  console.log(a)
}
foo() //1
console.log(a) //1

  在你看到上面阔以被运行成功,并打印出1时。你会觉得非常不可思议。这是因为在非严格模式的情况下,编译器检测到 a 没有被声明,它会在在全局隐式声明一个 a。这就是上面代码执行成功的原因。等同于

var a
function foo (){
  a = "1"
  console.log(a)
}
foo() //1
console.log(a) //1

这种情况会导致全局变量污染,因此在命名一个变量的时候请务必声明它。

相关文章

  • 变量声明提升和隐式变量声明

    变量声明提升原理   引擎会在解释 JavaScript代码之前首先对其进行编译。编译阶段中的一部分工作就是找到所...

  • 变量的查缺补漏

    显示声明和隐式声明 用 var 声明的变量是显示声明,只在当前作用域有效,例如: 直接赋值给一个变量则是隐式声明,...

  • Go 语言基础——变量常量的定义

    go语言不支持隐式类型转换,别名和原有类型也不能进行隐式类型转换go语言不支持隐式转换 变量 变量声明 声明变量不...

  • Golang learning 变量

    变量声明 (隐式转换,强制类型) 变量声明未使用为报错,防止随意声明无用变量,规范代码。 常量声明 常量声明未使...

  • 域解析

    函数变量及作用域 隐式全局变量:变量没有声明,直接赋值,执行到时,浏览器才会偷偷把变量提升为隐式全局变量 全局作用...

  • es6之声明变量、解构赋值和模板字符串

    一、声明变量 es5之前,声明变量只有var声明、隐式声明和函数声明。而es6中则多了let和const。 (1)...

  • 变量函数提升

    变量被提升 因为变量声明和函数声明会被解释为: 函数被提升 声明式函数会自动将声明放在前面并且执行赋值过程,而变量...

  • 2020-05-28 vue-admin-ui总结

    作用域:var在函数里定义的才是局部变量。直接使用变量不声明则是隐式全局变量,函数里也是全局的预解析:变量声明提升...

  • Kotlin的基础类型(一)

    声明变量 Kotlin是强类型语言,Kotlin要求所有的变量必须先声明后使用,声明变量时必须显式或隐式的指定变量...

  • 变量声明 var、let、const

    1. var变量声明提升 var声明的变量,发生变量声明提升;即:变量的声明被提升到该作用域的顶部 let 和 c...

网友评论

      本文标题:变量声明提升和隐式变量声明

      本文链接:https://www.haomeiwen.com/subject/vcjxhktx.html