JS不像C语言,C语言是先声明后使用,否则会报错。但JS中,有变量提升现象,可以先使用后声明。
JS存在变量提升,这个设计其实是低劣的,或者是语言实现时的一个副作用。它允许变量不声明就可以访问,或声明在后使用在前。
但在ES6加入let/const后,变了Hoisting就不存在了。
变量提升
把变量提升到函数top的地方。但要注意仅仅是变量提升,赋值并不提升。
var v = 'Hello World';
(function() {
alert(v); // undefined
var v = 'I love you';
})()
相当于:
var v = 'Hello World';
(function() {
var v;
alert(v);
var v = 'I love you';
})()
所以,才会提示说“undefined”。
(function(){
var a='One';
var b='Two';
var c='Three';
})()
实际上她是这个样子:
(function(){
var a,b,c;
a='One';
b='Two';
c='Three';
})()
这个时候就把变量提升了。
从这里,我们也学习到,我们在写js code 的时候,需要把变量放在块级作用域的顶端,比如我在上面所举的例子:var a,b,c;。防止出现意外。
函数提升
函数提升是把整个函数都提到前面去。
在我们写js code 的时候,我们有2中写法,一种是函数表达式,另外一种是函数声明方式。
我们需要重点注意的是:
- 只有函数声明形式才能被提升。
1、函数声明形式 【成功】
function myTest(){
foo();
function foo(){
alert("我来自 foo");
}
}
myTest();
2、函数表达式方式【失败】
function myTest(){
foo();
var foo =function foo(){
alert("我来自 foo");
}
}
myTest();