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变量提升深入理解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。
javascript学习笔记_浅谈基础语法,类型,变量
基础语法、类型、变量非数字值的判断方法:(因为Infinity和NaN他们不等于任何值,包括自身)1、用x!=x,当x为NaN时才返回true;2、用isNaN(x),当x为NaN或非
JavaScript学习笔记整理_关于表达式和语句
表达式和语句eval()只有一个参数参数非字符串时,直接返回这个参数;参数为字符串时,它把字符串当成JavaScript代码进行编译,编译失败则抛出语法错
JavaScript学习笔记整理_简单实现枚举类型,扑克牌应用
如下所示://实现枚举类型,扑克牌应用functioncreatEnum(p){//构造函数varEnumeration=function(){throw'cannotInstantiateEnumerations';};//重写原型并将原型赋值给变量protovar