对JavaScript中 this 关键词的理解



理解 this 关键词

自从我开始学习和使用 JavaScript 以来,就有一件事一直困扰着我,那就是 this 关键字。

当我开始学习 Vue 时,this 给我带来了恶梦。我花了很多时间去学习和实践,今天我将和大家分享我对 this 关键词的一些理解。

this 是面向对象语言的重要组成部分,但是JavaScript中的 this 与Java中的 this 关键字,还有Python中的 self 是不同的! JavaScript 中 this 指的是上下文中的对象,也就是说在函数中,this 指的是包含它的对象,this 的值取决于它的使用方式。

应用场景以及 this 的值有以下几种情况:

  • 默认情况thisglobal对象,即全局对象,指的是 window

  • 函数里thisglobal对象,和默认情况是一样的,但是在 严格 (strict)模式下,this 的值是 undefined

  • 方法内部this指的是所有者对象。(它是属于对象属性的函数)

  • 事件中this指的是触发事件的元素。

  • 箭头函数内部:使用箭头()=>定义函数时,它不会创造 this,而是一直引用它在函数外部引用的同一个对象。



具体实践

下面我们来看具体实践

函数内部

默认则是 window 对象

function test(){
    console.log(this)
}
test();

image.png

在严格模式下则为 undefined

function test(){
    "use strict";
    console.log(this)
}
test();

image.png



在方法内部

在方法内部 this 指的是在方法调用其中拥有该方法的对象。

const me = {
  name: "我想养只猫",
  show() {
    console.log(this.name);
  },
  info: {
    webSite: "uiuing.com",
    show() {
      console.log(this.webSite)  
    }
  }
};

me.show();

me.info.show();

image.png



在事件中

在事件中 this 则是这个dom对象,这个不需要多说,运行一下这段代码就自然知道了。

<body>
    <button onclick="run(this)"> CLICK ME!</button>
    <script>
        function run(data){
            console.log(data);
        }
    </script>
</body>

image.png



在箭头函数内

function 定义函数和 箭头函数的区别在使用 this 时格外明显,具体如下

<body>
    <button id="btn"> CLICK ME!</button>
    <script>
        let btn_el = document.getElementById("btn");

        btn_el.onclick =  function (){
            console.log("function 下的this:",this);
        };
        btn_el.click();

        btn_el.onclick = ()=>{
            console.log("箭头函数下的this:",this);
        };
        btn_el.click();
    </script>
</body>

image.png

你能发现区别吗?

  • 11
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我想养只猫 •͓͡•ʔ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值