var a = 20;
var foo = {
a: 40,
bar: function () {
var a = 10;
return this.a; //>=20
}
};
console.log(
foo.bar(), // 40
(foo.bar)(), // 40
(foo.bar = foo.bar)(), // 20
(foo.bar, foo.bar)(), // 20
(foo.bar.apply(window)), // 20
(foo.bar.apply(foo))// 40
);
第三和第四个不知道原理啊,有没js大神
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
5条回答 默认 最新
- danielinbiti 2015-01-12 16:40关注
经过赋值,运算符运算后,都是纯粹的函数,不是对象方法的引用。所以函数指向的this都是windows的
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料