在一道有趣的面试题中了解变量提升和函数提升

以下两道题目一样,实际上只是一道题目只是打印输出的位置不同:

需要了解的内容:

①  在浏览器进行编译的时候,变量声明和函数声明都会提升,并且函数声明的提升优先级大于变量声明的提升

②  函数表达式不可提升

题目一:

var getName = function() {
  console.log(4);
};
function getName() {
  console.log(5);
}
getName();  //4

//相当于
function getName() { // 函数声明的提升大于变量声明的提升 console.log(5); } var getName; getName = function() { // 函数表达式不会提升 console.log(4); }; getName(); // 4

题目二:

getName();  //5
var getName = function() {
    console.log(4);
  };
  function getName() {
    console.log(5);
  }

// 相当于:
function getName() {
  console.log(5);
}
var getName;
getName();    // 5
getName = function() {   
  console.log(4);
};

 

转载于:https://www.cnblogs.com/cxuer/p/9056921.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值