前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js变量提升 和函数提升

js变量提升 和函数提升

作者头像
ZEHAN
发布2020-09-25 11:06:48
1.3K0
发布2020-09-25 11:06:48
举报
文章被收录于专栏:前端开发ZEHAN前端开发ZEHAN

两个最简单的例子理解变量声明提升和函数声明提升 一、变量提升 变量提升即将变量声明提升到它所在作用域的最开始的部分 例1:

代码语言:javascript
复制
function fn () {
       var a ="hello world1";
      console.log(a); // hello world1
      console.log(b); //undefined
        var b = 'hello world2';
}
fn();

解析:为什么会出现这样的结果; 例1中 代码实际的运行情况应该是这样;

代码语言:javascript
复制
function fn () {
       var a ="hello world1";
      console.log(a); // hello world1
       var b;
      console.log(b); //undefined
       b = 'hello world2';
}

因为变量提升,很简单,就是把变量提升提到函数的最top的地方。 但是我需要说明的是,变量提升 只是提升变量的声明,并不会把赋值也提升上来

二、函数提升 js中创建函数有两种方式:一种是函数表达式,另外一种是函数声明方式。只有函数声明才存在函数提升!如: 例2:

代码语言:javascript
复制
console.log(fun1); // function fun1() {}   
console.log(fun2); // undefined  
function fun1() {}
var fun2 = function() {}

例2中代码的实际

代码语言:javascript
复制
function fun1() {} // 函数提升,整个代码块提升到文件的最开始 
console.log(fun1);   
console.log(fun2);   
var fun2 = function() {}

总结和注意点

1、变量提升

1、通常JS引擎会在正式执行之前先进行一次预编译,在这个过程中,首先将变量声明及函数声明提升至当前作用域的顶端,然后进行接下来的处理
2、如果当前作用域中存在此变量声明,无论它在什么地方声明,引用此变量时就会在当前作用域中查找,不会去外层作用域了
3、let和const关键字没有变量提升

2、函数提升

1、如果在同一个作用域中存在多个同名函数声明,后面出现的将会覆盖前面的函数声明
2、函数声明的优先级最高,会被提升至当前作用域最顶端,所以第一次调用时实际执行了下面定义的函数声明,然后第二次调用时,由于前面的函数表达式与之前的函数声明同名,故将其覆盖,以后的调用也将会打印同样的结果
3、函数的优先权是最高的,它永远被提升至作用域最顶部,然后才是函数表达式和变量按顺序执行
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 总结和注意点
    • 1、变量提升
      • 1、通常JS引擎会在正式执行之前先进行一次预编译,在这个过程中,首先将变量声明及函数声明提升至当前作用域的顶端,然后进行接下来的处理
      • 2、如果当前作用域中存在此变量声明,无论它在什么地方声明,引用此变量时就会在当前作用域中查找,不会去外层作用域了
      • 3、let和const关键字没有变量提升
    • 2、函数提升
      • 1、如果在同一个作用域中存在多个同名函数声明,后面出现的将会覆盖前面的函数声明
      • 2、函数声明的优先级最高,会被提升至当前作用域最顶端,所以第一次调用时实际执行了下面定义的函数声明,然后第二次调用时,由于前面的函数表达式与之前的函数声明同名,故将其覆盖,以后的调用也将会打印同样的结果
      • 3、函数的优先权是最高的,它永远被提升至作用域最顶部,然后才是函数表达式和变量按顺序执行
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档