var foo='hello';
(function(foo){
console.log(foo);
var foo=foo||'world';
console.log(foo);
})(foo);
console.log(foo); 三次分别输出什么?
JS代码自上而下执行的时候,自执行函数不在进行变量提升,但是函数内部的变量提升还进行吗?food ||“world”改怎样理解?
自执行函数变量提升问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
- Go 旅城通票 2017-08-01 02:02关注
等价于下面
var foo = 'hello'; (function (foo) { var foo = undefined; foo=//传入的foo的值 console.log(foo);//hello foo = foo || 'world';//因为foo有值所以没有赋值world console.log(foo);//hello })(foo); console.log(foo);//hello,变量作用域,变量普通类型和引用类型的问题
解决 无用评论 打赏 举报
悬赏问题
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器