变量提升和函数提升

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(); 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 像变量提升和函数提升这种偏学院派的问题在面试中出现的概率很高,在实际开发中也会影响到编程的效率。 前段时间在网上做...
    时和岁稔阅读 4,741评论 1 7
  • 在javascript里存在一种叫变量声明提升的东西。这里来详细的说一说,到底什么样的声明会提升,提升了什么东西。...
    xiaoyoo阅读 3,290评论 0 0
  • (注1:如果有问题欢迎留言探讨,一起学习!转载请注明出处,喜欢可以点个赞哦!)(注2:更多内容请查看我的目录。) ...
    love丁酥酥阅读 5,474评论 2 3
  • 1. 深入理解 js 的变量提升和函数提升 先了解:js没有块级作用域,只有全局作用域,和函数作用域 相同的函数名...
    adminlyrics阅读 1,937评论 0 0
  • 上一章|完美新娘(8) 方婷挑来挑去也没有挑到自己喜欢的婚纱,还抱怨这家店,没几件衣服就敢开店。夏雷提议要不要去别...
    石如一阅读 2,812评论 0 0