js变量提升深入理解

来源:爱站网时间:2020-05-26编辑:网友分享
在JS开发中变量这个东西在进行JS中起到很大的作用,对项目提升后的效果也是非常明显的,下文是爱站技术频道小编带给大家的js变量提升深入理解,一起随着小编的步伐来了解清楚操作过程吧!

在JS开发中变量这个东西在进行JS中起到很大的作用,对项目提升后的效果也是非常明显的,下文是爱站技术频道小编带给大家的js变量提升深入理解,一起随着小编的步伐来了解清楚操作过程吧!

JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部:

'use strict';

function foo() {
  var x = 'Hello, ' + y;
  alert(x);
  var y = 'Bob';
}
foo();

虽然是strict模式,但语句var x = 'Hello, ' + y;并不报错,原因是变量y在稍后申明了。但是alert显示Hello, undefined,说明变量y的值为undefined。这正是因为JavaScript引擎自动提升了变量y的声明,但不会提升变量y的赋值。

对于上述foo()函数,JavaScript引擎看到的代码相当于:

function foo() {
  var y; // 提升变量y的申明
  var x = 'Hello, ' + y;
  alert(x);
  y = 'Bob';
}

由于JavaScript的这一怪异的“特性”,我们在函数内部定义变量时,请严格遵守“在函数内部首先申明所有变量”这一规则。最常见的做法是用一个var申明函数内部用到的所有变量:

function foo() {
  var
    x = 1, // x初始化为1
    y = x + 1, // y初始化为2
    z, i; // z和i为undefined
  // 其他语句:
  for (i=0; i

通过爱站技术频道介绍的js变量提升深入理解,我们都已经了解了吧,大家可以按照上面介绍进行操作,加强巩固。

上一篇:vue 数组和对象不能直接赋值情况和解决方法

下一篇:javascript常见错误及解决方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载