JS 里为什么会有 this

 更新时间:2021年10月11日 09:31:31   作者:方应杭  
这篇文章主要介绍了JS 里为什么会有 this,文章主要从语言创造者(JS 之父的角度)来思考 this,我之前那篇讲 this 的文章是从使用者的角度写的,需要的朋友可以参考一下

1、需求

假设我们有一个对象

var person = {
    name: 'Frank',
    age: 18,
    phone: '13812345678',
    sayHi: function(){
      // 待补充
    },
    sayBye: function(){
      // 待补充
    }
}

这个 person 对象有 name age 属性,还有一个 sayHi 方法,现在的需求是:

调用 person.sayHi(...) ,打印出「你好,我是 Frank,今年 18 岁」。
调用 person.sayBuy(...) ,打印出「再见,记得我叫 Frank 哦,想约我的话打电话给我,我的电话是 13812345678」

求就是这么简单,通过达成这个需求,我们就能理解 this 的本质。

2、方案

var person = {
    ...
    sayHi: function(name, age){
      console.log('你好,我是 ${name},今年 ${age} 岁')
    },
    sayBye: function(name, phone){
      console.log('再见,记得我叫 ${name} 哦,想约我的话打电话给我,我的电话是 ${phone}')
    }
}

调用方式是

person.sayHi(person.name, person.age)
person.sayBye(person.name, person.phone)

别急,我知道这代码很傻,接下来改进。

3、第一次改进

上面方法中,每次都要在调用的时候自行选择 person.name 作为参数,真的很傻,不如直接传入一个 person代码如下:

var person = {
    ...
    sayHi: function(self){
      console.log('你好,我是 ${self.name},今年 ${self.age} 岁')
    },
    sayBye: function(self){
      console.log('再见,记得我叫 ${self.name} 哦,想约我的话打电话给我,我的电话是 ${self.phone}')
    }
}

调用方式是

person.sayHi(person)
person.sayBye(person)

稍微好一点了,但是这代码依然很傻。
为什么不能把参数里的 person 省掉,变成 person.sayHi() 就好了。

4、加糖

开发者最想要的调用方式是 person.sayHi()那么问题来了,如果 person.sayHi() 没有实参,person.sayHi 函数是如何接收到 person 的呢?

  • 方法1:依然把第一个参数 self 当做 person,这样形参就会永远比实参多出一个 self
  • 方法2:隐藏 self,然后用关键字 this 来访问 self

JS 之父选择了方法2,用 this 访问 selfPython 之父选择了方法1,留下 self 作为第一个参数。

过程如下:

// 用 this 之前:
sayHi: function(self){
    console.log('你好,我是 ${self.name},今年 ${self.age} 岁')
}
// 用 this 之后:
sayHi: function(){
    // this 就是 self
    console.log('你好,我是 ${this.name},今年 ${this.age} 岁')
}

5、费解

用了 this 之后,完整代码如下:

var person = {
    name: 'Frank',
    age: 18,
    phone: '13812345678',
    sayHi: function(){
      console.log('你好,我是 ${this.name},今年 ${this.age} 岁')
    },
    sayBye: function(){
      console.log('再见,记得我叫 ${this.name} 哦,想约我的话打电话给我,我的电话是 ${this.phone}')
    }
}

现在轮到新手疑惑了,这个 this 到底是个啥玩意儿?从哪来的呀?

实际this 是隐藏的第一个形参。在你调用 person.sayHi() 时,这个 person 会「变成」 this

6、存在问题

很多 JS 高手不屑于用 this,觉得 this 不够单纯。所以 JS 之父给高手们准备了无糖的 .call 方法。

person.sayHi.call(person) 就等价于 person.sayHi()

.call 的第一个参数就是显式的 person,没有任何语法糖。

所以高手一般用 obj.fn.call(null,1,2,3) 来手动禁用 this

这样一来 person.sayHi.call 的参数其实可以是任何对象。

也就是说 person.sayHi 虽然是 person 的方法,但是是可以调用在任何对象上的。

7、对象与函数

JS 没有类没有方法,只有对象和函数。

JS 加了 class 关键字之后,勉强弄出来一个假的类。

this 是连接对象和函数的桥梁。

相比于 JS,我更喜欢 Python 的方式,不使用 this 关键字,而是使用 self 形参,更易懂。

到此这篇关于JS 里为什么会有 this的文章就介绍到这了,更多相关JS 里为什么会有 this内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 国庆节到了,利用JS实现一个生成国庆风头像的小工具 详解实现过程

    国庆节到了,利用JS实现一个生成国庆风头像的小工具 详解实现过程

    明天就是国庆节了,最近看到好多好友换了国庆风的头像,感觉这个挺有意思,就找到了类似的源码研究了一番,并进行了改造(并非原创,只是进行了改造,只要想分享一下实现思路)。下面就来看看如何实现一键生成国庆风头像小工具。​
    2021-09-09
  • JS深入浅出Function与构造函数

    JS深入浅出Function与构造函数

    这篇文章主要介绍了JS深入浅出Function与构造函数,Function是一个构造函数,可以通过该构造函数去创建一个函数,创建的函数是一个Function对象,具体内容请参考下面文章的详细内容,需要的朋友可以参考一下
    2021-12-12
  • Three.js引用和环境搭建过程详解

    Three.js引用和环境搭建过程详解

    这篇文章主要为大家介绍了Three.js引用和环境搭建过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • Immer 功能最佳实践示例教程

    Immer 功能最佳实践示例教程

    这篇文章主要为大家介绍了Immer功能最佳实践示例教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • JavaScript数据类型对函数式编程的影响示例解析

    JavaScript数据类型对函数式编程的影响示例解析

    这篇文章主要为大家介绍了JavaScript数据类型对函数式编程的影响示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 微信小程序 五星评价功能的实现

    微信小程序 五星评价功能的实现

    这篇文章主要介绍了微信小程序 五星评价功能的实现的相关资料,这里附有实例代码及实现效果图,需要的朋友可以参考下
    2017-03-03
  • 微信小程序 摇一摇抽奖简单实例实现代码

    微信小程序 摇一摇抽奖简单实例实现代码

    这篇文章主要介绍了微信小程序 摇一摇抽奖简单实例实现代码的相关资料,这里实现摇一摇抽奖的功能,需要的朋友可以参考下
    2017-01-01
  • 经典的带阴影的可拖动的浮动层

    经典的带阴影的可拖动的浮动层

    经典的带阴影的可拖动的浮动层...
    2006-06-06
  • JavaScript实现队列结构过程

    JavaScript实现队列结构过程

    这篇文章主要介绍了JavaScript实现队列结构的过程,队列即Queue,它是受限的线性表,先进先出,受限之处在于它只允许在表的前端进行删除操作,下面我们一起进入文章学习更加详细内容,需要的朋友也可以参考一下
    2021-12-12
  • 微信小程序 封装http请求实例详解

    微信小程序 封装http请求实例详解

    这篇文章主要介绍了微信小程序 封装http请求实例详解的相关资料,需要的朋友可以参考下
    2017-01-01

最新评论