微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

js变量提升深入理解

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

rush:js;"> '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引擎看到的代码相当于:

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

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

rush:js;"> function foo() { var x = 1,// x初始化为1 y = x + 1,// y初始化为2 z,i; // z和i为undefined // 其他语句: for (i=0; i<100; i++) { ... } }

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐