博主信息
博文 11
粉丝 0
评论 0
访问量 17908
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
JS 里为什么会有 this
**沐曦??
原创
698人浏览过

1、需求
2、方案
3、第一次改进
4、加糖
5、费解
6、存在问题
7、对象与函数

1、需求
假设我们有一个对象

1
2
3
4
5
6
7
8
9
10
11
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、方案
1
2
3
4
5
6
7
8
9
var person = {

sayHi: function(name, age){
console.log(‘你好,我是 ${name},今年 ${age} 岁’)
},
sayBye: function(name, phone){
console.log(‘再见,记得我叫 ${name} 哦,想约我的话打电话给我,我的电话是 ${phone}’)
}
}
调用方式是

1
2
person.sayHi(person.name, person.age)
person.sayBye(person.name, person.phone)
别急,我知道这代码很傻,接下来改进。

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

1
2
3
4
5
6
7
8
9
var person = {

sayHi: function(self){
console.log(‘你好,我是 ${self.name},今年 ${self.age} 岁’)
},
sayBye: function(self){
console.log(‘再见,记得我叫 ${self.name} 哦,想约我的话打电话给我,我的电话是 ${self.phone}’)
}
}
调用方式是

1
2
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 访问 self。Python 之父选择了方法1,留下 self 作为第一个参数。

过程如下:

1
2
3
4
5
6
7
8
9
// 用 this 之前:
sayHi: function(self){
console.log(‘你好,我是 ${self.name},今年 ${self.age} 岁’)
}
// 用 this 之后:
sayHi: function(){
// this 就是 self
console.log(‘你好,我是 ${this.name},今年 ${this.age} 岁’)
}

5、费解
用了 this 之后,完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
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 形参,更易懂。

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学