小白学前端(二) 为什么对象方法里的函数this指向window?

1. 函数里的函数中的 this 就是在 global 环境下的 window

2. 对象方法里的函数中的 this 为什么指向 window?


如果按照我的理解,那么infunc() 其实和 o 并没有关系
infunc() 在object里 其实就和在 window / global 中执行是等价的... 具体是为什么估计要等更加了解js的底层原理了...

还可以参考这篇文章 https://zhuanlan.zhihu.com/p/23804247

再赋一个例子

如果不给map一个this, 里面的function会把this指向全局,函数都是这样的?
把调用normalize的this赋予map后即可
或者利用箭头函数


3. 对象方法里的箭头函数 this 却是动态绑定的?


有没有大神可以详细的解释下这是为什么?

另一个奇怪的this现象:

可以这么解释,如果只是o.f,那么x()就相当于是一个 全局函数
function x (){ return this.prop } x(); x调用发生在window中,window.prop不存在,即undefined
如果是o.f() 那么this.prop 就已经执行为 o.prop 了

推荐阅读更多精彩内容

  • ES6 http://es6.ruanyifeng.com 目录 1 let 和 const 命令 2 变量的解构...
    常青1890阅读 4,621评论 0 41
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 538评论 0 0
  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 5,300评论 0 38
  • pdf下载地址:Java面试宝典 第一章内容介绍 20 第二章JavaSE基础 21 一、Java面向对象 21 ...
    王震阳阅读 70,800评论 26 501
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    泰迪学长_阅读 1,677评论 0 12