JS|JS 里为什么会有 this
目录
- 1、需求
- 2、方案
- 3、第一次改进
- 4、加糖
- 5、费解
- 6、存在问题
- 7、对象与函数
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
。
this
访问 self
。Python
之父选择了方法1,留下 self 作为第一个参数。过程如下:
// 用 this 之前:sayHi: function(self){console.log('你好,我是 ${self.name},今年 ${self.age} 岁')}// 用 this 之后:sayHi: function(){// this 就是 selfconsole.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|JS 里为什么会有 this】到此这篇关于JS 里为什么会有 this的文章就介绍到这了,更多相关JS 里为什么会有 this内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 你到家了吗
- 为什么你的路演总会超时()
- 闲杂“细雨”
- 财商智慧课(六)
- 村里的故事|村里的故事 --赵大头
- 吃了早餐,反而容易饿(为什么?)
- 情节33.0
- 生命过客——第10章|生命过客——第10章 初为人母
- 你眼里的不公平,其实很公平
- 为什么越花钱的人越有钱,越舍不得花钱的人却越穷()