首先js引擎在读取js代码时会进行两个步骤:
好吧,举几个好吃的栗子:
例子1:
console.log(a); //输出结果 undefined
var a = 10;
// 以上代码输出 undefined
// 原因: 变量提升( 把变量声明提升到当前执行环境的最顶端)
// 上段代码相当于:
var a;
console.log(a); //由于未赋值 所以输出undefined
a = 10;
例2:
foo();
function foo() {
console.log("aaa");
}
// 结果输出: aaa
// 原理:函数声明提升 (函数声明提升直接把整个函数提到执行环境的最顶端)
// 相当于:
function foo() {
console.log("aaa");
}
foo();
// 变量提升只提升函数名 而函数提升会提升整个函数题 注意:函数提升在变量提升上面。
例3:
foo();
var foo = function () {
console.log("aaa");
}
// 运行结果是: foo is not a function
// 原因: 还是进行了变量提升
// 相当于:
var foo;
console.log(foo); //undefined
foo(); //foo is not a function
foo = function () {
console.log("aaa");
}
// 上面代码输出undefined 是因为变量提升后并没有赋值因此输出undefined
// 输出foo is not a function 原因是:js解析遇到 foo()时会默认当做函数来解析
例4:
console.log(foo);
var foo = 10;
console.log(foo);
function foo() {
console.log(10);
}
console.log(foo);
// 输出结果:
function () { //67行输出
console.log(10);
}
10 //69行输出
10 //72行输出/
// 原理:
// 相当于:
function foo() {
console.log(10);
}
var foo;
console.log(foo);
foo = 10;
console.log(foo);
console.log(foo);
// 注意: 函数提升在变量提升上面,第一个console.log(foo);为什么会输出函数题呢,原因在于 var foo; 并未有赋值只是声明,因此他会调用上面的值
// 例如:
var b = 10;
b = 10;
console.log(b); //10 输出上一个值不会输出undefined
// 但是更改后:
var b = 10;
b = 20;
console.log(b); //20 输出20不是上一个值
总结一下:
关于变量提升,一定要注意细心思考一下,还有就是要牢记,函数提升在变量提升之上;希望刚入行的小伙伴看到后能有所领悟。---
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!