js变量提升深入理解

 更新时间:2016年09月16日 12:41:45   投稿:jingxian  
下面小编就为大家带来一篇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<100; i++) {
    ...
  }
}

以上这篇js变量提升深入理解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • JS中Object.assign方法的使用

    JS中Object.assign方法的使用

    这篇文章介绍了JS中Object.assign方法的使用方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 使用Script元素发送JSONP请求的方法

    使用Script元素发送JSONP请求的方法

    下面小编就为大家带来一篇使用Script元素发送JSONP请求的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • 微信小程序wx:for循环的实例详解

    微信小程序wx:for循环的实例详解

    在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。这篇文章主要介绍了微信小程序wx:for循环的相关知识,需要的朋友可以参考下
    2018-10-10
  • javascript小数四舍五入多种方法实现

    javascript小数四舍五入多种方法实现

    javascript小数四舍五入在工作中经常会使用到,今天本文整理了一些常用的小窍门,需要了解的朋友可以参考下
    2012-12-12
  • JavaScript 高级篇之DOM文档,简单封装及调用、动态添加、删除样式(六)

    JavaScript 高级篇之DOM文档,简单封装及调用、动态添加、删除样式(六)

    学习是有趣的,但有过滤的学习内容就更好,本博主就专门为刚接触javascript客户端编程的朋友提供及分享个人学习经历!建议大家看看:(汤姆大叔的博客)
    2012-04-04
  • JavaScript中二维数组的创建技巧

    JavaScript中二维数组的创建技巧

    二维数组本质上是以数组作为数组元素的数组,即"数组的数组",类型说明符 数组名[常量表达式][常量表达式]。二维数组又称为矩阵,行列数相等的矩阵称为方阵。对称矩阵a[i][j] = a[j][i],对角矩阵:n阶方阵主对角线外都是零元素
    2021-11-11
  • javascript parseInt 函数分析(转)

    javascript parseInt 函数分析(转)

    javascript的parseInt函数的一些问题分析
    2009-03-03
  • Javascript之String对象详解

    Javascript之String对象详解

    本文主要介绍javascript中的String对象的用法,讲解的很详细,希望能给大家做一个参考。
    2016-06-06
  • JavaScript中的事件循环方式

    JavaScript中的事件循环方式

    这篇文章主要介绍了JavaScript中的事件循环方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Javascript中的关键字和保留字整理

    Javascript中的关键字和保留字整理

    ECMA-262中描述了一组具有特定用途的关键字,关键字属于语言保留,不可以用于标示符,学习js的朋友可以看看
    2014-10-10

最新评论