一道 js 函数提升的问题

复制代码
foo();
var a=true;
if(a){
    function foo(params) {
       console.log("a") 
    }
}else{
    function foo(params) {
        console.log("b") 
    }
}
复制代码

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

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

复制代码
"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》

posted @   蓓蕾心晴  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
历史上的今天:
2022-03-07 swiper.js轮播在iOS下禁用上拉下拉回弹问题解决
点击右上角即可分享
微信分享提示