前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >class中函数的this指向

class中函数的this指向

作者头像
骤雨重山
发布2023-04-27 20:24:08
2210
发布2023-04-27 20:24:08
举报
文章被收录于专栏:骤雨重山骤雨重山

定义一个基础的类

代码语言:javascript
复制
class Person {
    constructor(name = '杜恒') {
        this.name = name
    }
    speak() {
        console.log(this);
    }
}

将上面的类实例出一个对象p,并调用p的speak方法

代码语言:javascript
复制
const p = new Person()
p.speak() // Person {name: "杜恒"}

上面的打印结果显示由类构造出的实例对象,因此this会指向由类构造出的实例对象

尝试将p实例对象身上的speak方法赋值给另一个变量进行调用

代码语言:javascript
复制
const test = p.speak
test() // undefined

打印undefind,因此上面的方法可以改写成如下

代码语言:javascript
复制
const test = function () {
    "use strict"
    console.log(this);
}
test() // undefined

由此可以得出,在class中,定义的方法,class会默认在函数体内开启严格模式,严格控制this的指向

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 定义一个基础的类
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档