对JavaScript中 this 关键词的理解

简介: 对JavaScript中 this 关键词的理解

理解 this 关键词


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


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


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


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


  • 默认情况:this指global对象,即全局对象,指的是 window;
  • 函数里:this指global对象,和默认情况是一样的,但是在 严格 (strict)模式下,this 的值是 undefined;
  • 方法内部:this指的是所有者对象。(它是属于对象属性的函数)
  • 事件中:this指的是触发事件的元素。
  • 箭头函数内部:使用箭头()=>定义函数时,它不会创造 this,而是一直引用它在函数外部引用的同一个对象。



具体实践

下面我们来看具体实践


函数内部

默认则是 window 对象


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

36.png


在严格模式下则为 undefined

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

37.png

在方法内部

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

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

38.png



在事件中

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

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


39.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>

40.png你能发现区别吗?


目录
相关文章
|
2天前
|
自然语言处理 JavaScript 前端开发
在JavaScript中,this关键字的行为可能会因函数的调用方式而异
【5月更文挑战第9天】JavaScript中的`this`关键字行为取决于函数调用方式。在非严格模式下,直接调用函数时`this`指全局对象,严格模式下为`undefined`。作为对象方法调用时,`this`指向该对象。用`new`调用构造函数时,`this`指向新实例。通过`call`、`apply`、`bind`可手动设置`this`值。在回调和事件处理中,`this`可能不直观,箭头函数和绑定方法可帮助管理`this`的行为。
11 1
|
2天前
|
JavaScript 前端开发
深入探索JavaScript:如何改变this的指向
深入探索JavaScript:如何改变this的指向
|
2天前
|
JavaScript 前端开发
【专栏】`Function.prototype.apply` 在JavaScript中用于动态设定函数上下文(`this`)和参数列表
【4月更文挑战第29天】`Function.prototype.apply` 在JavaScript中用于动态设定函数上下文(`this`)和参数列表。它接受两个参数:上下文对象和参数数组。理解`apply`有助于深入JS运行机制。文章分三部分探讨其原理:基本概念和用法、工作原理详解、实际应用与注意事项。在应用中要注意性能、参数类型和兼容性问题。`apply`可用于动态改变上下文、传递参数数组,甚至模拟其他语言的调用方式。通过深入理解`apply`,能提升代码质量和效率。
|
2天前
|
JavaScript 前端开发 数据安全/隐私保护
|
2天前
|
自然语言处理 JavaScript 前端开发
js_关键字this指向哪里?
js_关键字this指向哪里?
5 0
|
2天前
|
JavaScript 前端开发
js开发:请解释this关键字在JavaScript中的用法。
【4月更文挑战第23天】JavaScript的this关键字根据执行环境指向不同对象:全局中指向全局对象(如window),普通函数中默认指向全局对象,作为方法调用时指向调用对象;构造函数中指向新实例,箭头函数继承所在上下文的this。可通过call、apply、bind方法显式改变this指向。
8 1
|
2天前
|
自然语言处理 JavaScript 前端开发
解析JavaScript中的this:新手常见误区与应对策略
【4月更文挑战第1天】本文介绍了JavaScript中`this`的关键作用及其常见误区,包括作用域与调用上下文混淆、回调函数中的`this`绑定、构造函数使用、对象字面量方法与普通函数的区别以及严格模式的影响。通过理解四条绑定规则(显式、new、隐式、默认)和采取相应避免策略,开发者能更好地掌握和运用`this`,提高编程效率和代码质量。
21 1
|
2天前
|
JavaScript 前端开发 开发者
解密JavaScript中this的指向问题
解密JavaScript中this的指向问题
159 2
|
2天前
|
分布式计算 JavaScript 前端开发
JS中函数的this指向(二)
JS中函数的this指向
42 0
|
2天前
|
Dart JavaScript 前端开发
JS中函数的this指向(一)
JS中函数的this指向
33 0