变量提升和函数提升

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(); 

你可能感兴趣的:(变量提升和函数提升)