首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >一道 js 函数提升的问题

一道 js 函数提升的问题

作者头像
蓓蕾心晴
发布2023-03-08 13:58:28
发布2023-03-08 13:58:28
2550
举报
文章被收录于专栏:前端小叙前端小叙
代码语言:javascript
复制
foo();
var a=true;
if(a){
    function foo(params) {
       console.log("a") 
    }
}else{
    function foo(params) {
        console.log("b") 
    }
}

思考下,上面代码执行会输出什么?

再看下面的👇🏻执行会输出什么?

代码语言:javascript
复制
"use strict"
foo();
var a=true;
if(a){
    function foo(params) {
       console.log("a") 
    }
}else{
    function foo(params) {
        console.log("b") 
    }
}

答:1. 输出  Uncaught TypeError: foo is not a function

2. 输出 Uncaught ReferenceError: foo is not defined

个人理解:

第一个在非严格模式下,函数 foo 会进行函数提升,但是不会进行赋值,所以在 foo 执行的时候 ,foo=undefined,则报类型错误

第二个在严格模式下,函数 foo 不会进行函数提升,在 foo 执行的时候,此时 foo 未定义,则报引用错误。

摘抄:

一个普通块内部的函数声明通常会被提升到所在作用域的顶部,这个过程不会像上面的代码暗示的那样可以被条件判断所控制。

摘自 《你不知道的 JavaScript》

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-03-07,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档