CD's blog CD's blog
首页
  • HTMLCSS
  • JavaScript
  • Vue
  • TypeScript
  • React
  • Node
  • Webpack
  • Git
  • Nestjs
  • 小程序
  • 浏览器网络
  • 学习笔记

    • 《TypeScript 从零实现 axios》
    • Webpack笔记
  • JS/TS教程

    • 《现代JavaScript》教程
🔧工具方法
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

CD_wOw

内卷的行情,到不了的梦
首页
  • HTMLCSS
  • JavaScript
  • Vue
  • TypeScript
  • React
  • Node
  • Webpack
  • Git
  • Nestjs
  • 小程序
  • 浏览器网络
  • 学习笔记

    • 《TypeScript 从零实现 axios》
    • Webpack笔记
  • JS/TS教程

    • 《现代JavaScript》教程
🔧工具方法
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 简介

  • JavaScript 基础知识

  • 数据类型

  • 函数进阶内容

    • 构造函数
    • this原理
      • 问题的由来
      • 内存的数据结构
    • 递归和堆栈
    • 全局对象
    • 装饰器模式和转发,call/apply
    • Rest 参数与 Spread 语法
    • 函数对象,NFE
    • 函数绑定
    • 变量作用域,闭包
    • new Function 语法
    • 深入理解箭头函数
    • 旧时的 "var"
    • 调度:setTimeout 和 setInterval
  • 对象属性配置

  • 原型,继承

  • 类

  • 错误处理

  • Promise,asyncawait

  • Generator,高级 iteration

  • 模块

  • 杂项

  • 《现代JavaScript》教程
  • 函数进阶内容
CD_wOw
2020-12-05
目录

this原理

# 问题的由来

let obj = {
	foo: function () {}
};
let foo = obj.foo;

// 写法一
obj.foo();

// 写法二
foo();
1
2
3
4
5
6
7
8
9
10

在此代码中,虽然obj.foo和foo指向同一个函数,但是执行结果可能不一样:

let obj = {
    foo: function () {
        console.log(this.bar)
    },
    bar: 1
};
let foo = obj.foo;
let bar = 2;

obj.foo(); // 1

foo(); // 2
1
2
3
4
5
6
7
8
9
10
11
12

这种差异的原因,就在于函数体内部调用了this关键字。

很多教科书会告诉你,this指的是函数运行时所在的环境, 对于obj.foo来说,foo运行在obj环境,所以this指向obj;

对于foo()来说,foo运行在全局环境,所以this指向全局环境。

所以,两者的运行结果不一样。

但是,为什么会这样?为什么obj.foo就是在obj环境执行,而一旦let foo = obj.foo,foo()就变成全局环境执行?

# 内存的数据结构

JavaScript之所以有this的设计,跟内存里面的数据结构有关系。

let obj = { foo: 5 };
1

此代码将一个对象赋值给obj,JavaScript引擎会先在内存里面,生成一个对象{ foo: 5 },然后把这个对象的内存地址赋值给变量obj。

也就是说,变量obj是一个地址。后面要读取obj.foo,引擎先从obj拿到内存地址,然后再从该地址读出原始的对象,返回它的foo属性。

或者说,当前函数体内的this,谁调用了就指向谁

编辑 (opens new window)
#现代JavaScript
上次更新: 2021/08/22, 01:09:59
构造函数
递归和堆栈

← 构造函数 递归和堆栈→

最近更新
01
gsap动画库学习笔记 - 持续~
06-05
02
远程组件加载方案笔记
05-03
03
小程序使用笔记
03-29
更多文章>
Theme by Vdoing | Copyright © 2020-2023 CD | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式