js的怪异代码题记录
题目一
1 2 3 4 5 6 7 8 | var a = 0 if ( true ) { a=1; function a() { return 3} a=2 console.log(a) // 2 } console.log(a) //1<br>// 题目看起来很怪,全局变量在中间似乎发生了变化 |
逐步解析
console.log(a, '1') var a = 0 console.log(a,'2'); if (true) { console.log(a,'3');// function... a = 1; console.log(a,'4');// 1 function a() { return 3 } console.log(a,'5');// 1 a = 2; console.log(a,'6');// 2 } console.log(a,'7'); // 1
可以看到在块级作用域中定义同名函数之后发生的变量赋值就不是对全局作用域的a改变了
那我们改变函数顺序,再来测试一下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | console.log(a, '1' ) var a = 0 console.log(a, '2' ); if ( true ) { console.log(a, '3' ); // function... function a() { return 3 } console.log(a, '4' ); // function... a = 1; console.log(a, '5' ); // 1 a = 2; console.log(a, '6' ); // 2 } console.log(a, '7' ); // function... |
结果函数在块级作用域中定义时,赋值为全局变量a函数,以至于之后的a赋值都没赋值给全局变量a上。
结论:这是道很怪的题目,可能是为了增加面试题差异化,水平不够,只能解析到这里。
以下是别人对js块级作用域声明的理解,我阅读之后发现js弱类型带来的问题很大,尽量用typescript可能是现在最优解
研究js的块级作用域中的变量声明和函数声明 - 掘金
https://juejin.cn/post/6844903955814694919
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话