揭开`this`的神秘面纱:探索 JavaScript 中的上下文密钥(上)

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 一、引言
    • 介绍`this`关键字在 JavaScript 中的重要性。
  • 二、`this`的基本概念
    • 解释`this`的定义和作用。
  • 三、不同的绑定方式
    • 介绍`this`的四种绑定方式:默认绑定、隐式绑定、显式绑定和 new 绑定。

一、引言

介绍this关键字在 JavaScript 中的重要性。

this 关键字在 JavaScript 中具有非常重要的作用,它用于表示当前执行上下文对象,即当前函数所在的对象

this 关键字可以用来访问对象的属性和方法,以及调用对象的方法和访问对象的属性。

this 关键字在 JavaScript 中具有以下重要性:

  1. 确定当前对象的属性:在 JavaScript 中,可以使用 this 关键字来访问对象的属性。例如,this.name 可以用来访问对象的 name 属性。

  2. 调用对象的方法:在 JavaScript 中,可以使用 this 关键字来调用对象的的方法。例如,this.sayHello() 可以用来调用对象的 sayHello 方法。

  3. 访问原型链上的属性和方法:JavaScript 中每个对象都有一个原型链,可以通过 this 关键字访问原型链上的属性和方法。例如,this.prototype.age 可以用来访问原型链上的 age 属性。

  4. 避免全局变量和全局函数:使用 this 关键字可以避免全局变量和全局函数的命名冲突和代码污染。例如,可以使用 varlet 关键字定义全局变量,但是不能直接使用全局变量,而是需要使用 this 关键字访问。

  5. 访问闭包中的变量和方法:在 JavaScript 中,闭包中的变量和方法是私有的,不能直接访问。但是,可以使用 this 关键字访问闭包中的变量和方法。例如,this.counter 可以用来访问闭包中的 counter 变量。

  6. 避免函数嵌套:在 JavaScript 中,函数嵌套会导致函数内部的变量被覆盖,从而无法访问。但是,使用 this 关键字可以避免函数嵌套的问题。例如,var counter = 0;var counter = 0; 定义了两个变量,但是使用 this 关键字可以避免变量被覆盖的问题。

综上所述,this 关键字在 JavaScript 中具有非常重要的作用,它可以帮助我们访问对象的属性和方法,调用对象的方法和访问对象的属性,访问原型链上的属性和方法,避免全局变量和全局函数的命名冲突和代码污染,访问闭包中的变量和方法,以及避免函数嵌套的问题。因此,在 JavaScript 中,我们需要熟练掌握 this 关键字的重要性,并正确地使用它来处理对象和函数之间的关系。

二、this的基本概念

解释this的定义和作用。

this 是一个 JavaScript 关键字,它用于表示当前执行上下文对象
在函数中,this 的值取决于函数是否被作为构造函数调用,或者是否被作为普通函数调用

1. 当函数作为构造函数被调用时:

如果函数被作为构造函数调用,那么 this值会自动绑定到新创建的对象上。例如:

function Person(name, age) {
  this.name = name;
  this.age = age;
}

var person = new Person("张三", 25);
console.log(person.name); // 输出 "张三"

在这个例子中,Person 函数作为构造函数被调用,创建了一个新的 Person 对象。由于 this 的值自动绑定到新创建的对象上,因此 this.namethis.age 分别被绑定到对象的 nameage 属性上。

2. 当函数作为普通函数被调用时:

如果函数被作为普通函数调用,那么 this值会指向全局对象(通常是 window 对象)。例如:

function sayHello() {
  console.log("Hello, world!");
}

sayHello(); // 输出 "Hello, world!"

在这个例子中,sayHello 函数作为普通函数被调用,由于 this 的值指向全局对象,因此 console.log 中的 "Hello, world!" 被输出到全局对象 window 上。

3. 当函数作为参数传递给另一个函数时:

如果函数作为参数传递给另一个函数,那么 this 的值会指向接收函数的 this 值。例如:

function logMessage(message) {
  console.log(message);
}

var logMessage = logMessage;
logMessage("Hello, world!"); // 输出 "Hello, world!"

在这个例子中,logMessage 函数被作为参数传递给另一个函数 logMessage,由于接收函数的 this 值指向全局对象 window,因此 logMessage 中的 console.log 中的 "Hello, world!" 被输出到全局对象 window 上。

综上所述,this 是一个非常重要的关键字,它可以帮助我们访问对象的属性和方法,调用对象的方法和访问对象的属性,以及确定函数的执行上下文。因此,在 JavaScript 中,我们需要熟练掌握 this 的定义和作用,并正确地使用它来处理对象和函数之间的关系。

三、不同的绑定方式

介绍this的四种绑定方式:默认绑定、隐式绑定、显式绑定和 new 绑定。

在 JavaScript 中,this 有四种绑定方式,分别是默认绑定、隐式绑定、显式绑定和 new 绑定。这四种绑定方式分别适用于不同的场景,下面我们来详细介绍这四种绑定方式。

  1. 默认绑定(Function 函数默认绑定)

当函数作为普通函数调用时,this 的默认绑定方式是全局对象(通常是 window 对象)。例如:

function sayHello() {
 console.log("Hello, world!");
}

sayHello(); // 输出 "Hello, world!"

在这个例子中,sayHello 函数作为普通函数被调用,由于 this 的默认绑定方式是全局对象,因此 console.log 中的 "Hello, world!" 被输出到全局对象 window 上。

  1. 隐式绑定(函数内变量默认绑定)

在函数内部,如果变量没有被赋值,它会自动绑定到 this。例如:

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

sayHello(); // 输出 window

在这个例子中,sayHello 函数内部的 this 指向全局对象 window,因此 console.log 中的输出结果是 window

  1. 显式绑定(使用 call 方法或 apply 方法显式绑定)

我们可以使用 call 方法或 apply 方法来显式地绑定 this。例如:

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

sayHello.call(null); // 输出 undefined
sayHello.call(window); // 输出 window

在这个例子中,我们使用 call 方法将 this 显式地绑定到全局对象 window 上,因此 console.log 中的输出结果是 window

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

sayHello.apply(null); // 输出 undefined
sayHello.apply(window); // 输出 window
  1. new 绑定(使用 new 关键字创建对象时绑定)

当我们使用 new 关键字创建对象时,this 会自动绑定到新创建的对象上。例如:

function Person(name, age) {
 this.name = name;
 this.age = age;
}

var person = new Person("张三", 25);
console.log(person.name); // 输出 "张三"

在这个例子中,我们使用 new 关键字创建了一个 Person 对象,因此 this 的绑定方式是该对象本身。因此,我们在函数内部使用 this.name 可以正确地访问对象的属性。

总结一下,四种绑定方式分别是:

  1. 默认绑定(Function 函数默认绑定):当函数作为普通函数调用时,this 的默认绑定方式是全局对象(通常是 window 对象)。
  2. 隐式绑定(函数内变量默认绑定):在函数内部,如果变量没有被赋值,它会自动绑定到 this
  3. 显式绑定(使用 call 方法或 apply 方法显式绑定):我们可以使用 call 方法或 apply 方法来显式地绑定 this
  4. new 绑定(使用 new 关键字创建对象时绑定):当我们使用 new 关键字创建对象时,this 会自动绑定到新创建的对象上。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/257262.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

c语言编写http服务器(Linux下运行)

参考文章&#xff1a;https://blog.csdn.net/baixingyubxy/article/details/125964986?spm1001.2014.3001.5506 上面是详细讲解&#xff0c;我这篇是总结了他的代码&#xff0c;因为他没给整体代码 所有代码&#xff1a; #include <stdio.h> #include <stdlib.h&g…

Python Django Jet:优化 Django 后台管理

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 大家好&#xff0c;今天分享 Python 中的 Django Jet 库。 Github项目地址&#xff1a;https://github.com/geex-arts/django-jet Django Jet 是一个强大的 Django 后台管理界面扩展&#xff0c;旨在提供更现代…

人工智能125个常用名词解释

1 什么是人工智能 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;是指计算机系统通过模拟人类的思维和行为来完成特定任务的技术和方法。人工智能的研究涉及多个学科&#xff0c;包括计算机科学、数学、心理学、哲学等领域。 人工智能可以被分为…

SVM —— 理论推导

SVM 支持向量线性可分最大间隔超平面最大间隔超平面的推导支持向量分类间隔的推导最优化问题 对偶问题拉格朗日乘子法强对偶性 SVM 优化软间隔解决问题优化目标及求解 核函数线性不可分核函数的作用常见核函数 SVM 算法优缺点 支持向量机&#xff08;Support Vector Machine&am…

Collecting package metadata (current_repodata.json): failed(解决方案)

如果有重装过anaconda&#xff0c;在C盘的用户目录下&#xff0c;会有一个名叫.condarc的文件会自动生成。 当使用conda install和conda create命令会出现下面的问题&#xff1a;Collecting package metadata (current_repodata.json): failed 解决方案&#xff1a; 1.打开Anac…

Leetcod面试经典150题刷题记录 —— 双指针篇

双指针篇 1. 验证回文串Python3 2. 判断子序列Python3双指针 3. 两数之和 II - 输入有序数组Python3 4. 盛最多水的容器Python3双指针 5. 三数之和 1. 验证回文串 题目链接&#xff1a;验证回文串 - leetcode 题目描述&#xff1a; 如果在将所有大写字符转换为小写字符、并移除…

Spring Cloud + Vue前后端分离-第6章 通用代码生成器开发

Spring Cloud Vue前后端分离-第6章 通用代码生成器开发 6-1 代码生成器原理介绍 1.增加generator模块&#xff0c;用于代码生成 2.集成freemarker 通用代码生成器开发 FreeMarker 是一款模版引擎&#xff0c;通过模板生成文件&#xff0c;包括html页面&#xff0c;excel …

基于vue+element-plus+echarts制作动态绘图页面(柱状图,饼图和折线图)

前言 我们知道echarts是一个非常强大的绘图库&#xff0c;基于这个库&#xff0c;我们可以绘制出精美的图表。对于一张图来说&#xff0c;其实比较重要的就是配置项&#xff0c;填入不同的配置内容就可以呈现出不同的效果。 当然配置项中除了样式之外&#xff0c;最重要的就是…

腾讯云debian服务器的连接与初始化

目录 1. 远程连接2. 软件下载3. 设置开机自启动 1. 远程连接 腾讯云给的服务器在安装好系统之后&#xff0c;只需要在防火墙里面添加一个白名单&#xff08;ip 或者域名&#xff09;就能访问了。 防火墙添加本机WLAN的IPv4白名单&#xff0c;本地用一个远程工具连接&#xff…

C++设计模式之——命令模式

命令模式 概念创建步骤示例示例一代码实现运行结果 示例二代码实现运行结果 示例三示例代码运行结果 示例四代码实现运行结果 应用场景 概念 命令模式是一种行为型设计模式&#xff0c;它允许将请求封装为一个对象&#xff0c;从而使得可以参数化客户端请求、将请求排队或者记…

npm login报错:Public registration is not allowed

npm login报错:Public registration is not allowed 1.出现场景2.解决 1.出现场景 npm login登录时,出现 2.解决 将自己的npm镜像源改为npm的https://registry.npmjs.org/这个&#xff0c;解决&#xff01;

安防视频云平台/可视化监控云平台EasyCVR获取设备录像失败,该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。GB28181音视频流媒体视频平台EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视…

打响指针的第一枪:指针家族

前言 指针其实是我们学习C语言中最难的知识点&#xff0c;很多人在学习指针的时候会被绕晕&#xff0c;包括博主也是&#xff0c;当初百思不得其解&#xff0c;脑袋都要冒烟了&#xff0c;本来打算在学习指针的时候就写一篇博客&#xff0c;但是当初自己的能力还是没有办法去完…

harmonyOS 自定义组件基础演示讲解

上文 HarmonyOS组件属性控制 链式编程格式推荐我们讲了一些系统组件 可以传入一些事件和参数 来达到一些不同的效果 其实 我们还可以用自己写的组件 那么 组件这么写&#xff1f; 其实 我们的 page 内部结果 就是一个组件 harmonyOS的概念 万物皆组件 那么 我们就可以在他下面…

低代码软件开发的革命

一、前言 如果一个概念能在科技圈火起来&#xff0c;它往往兼具字面简明和内涵丰富的特征&#xff0c;并具有某种重塑产业格局的潜力。低代码&#xff08;Low Code&#xff09;就是这样一个典型。顾名思义&#xff0c;低代码是指少用代码&#xff0c;甚至不用代码&#xff0c;仅…

自动化测试 (五) 读写64位操作系统的注册表

自动化测试经常需要修改注册表 很多系统的设置&#xff08;比如&#xff1a;IE的设置&#xff09;都是存在注册表中。 桌面应用程序的设置也是存在注册表中。 所以做自动化测试的时候&#xff0c;经常需要去修改注册表 Windows注册表简介 注册表编辑器在 C:\Windows\regedit…

Netty入门基础知识

简介 Netty是一款高性能java网络编程框架&#xff0c;被广泛应用在中间件、直播、社交、游戏等领域。Netty对java NIO进行高级封装&#xff0c;简化了网络应用的开发过程。 stream与channel stream不会自动缓冲数据&#xff0c;channel会利用系统提供的发送缓冲区&#xff0c;接…

科创金融的向善力量:浙商银行多措并举赋能科创企业,打造科技金融服务生态圈

近日&#xff0c;浙商银行科技金融服务发布会在杭州举行。 发布会以“智汇科创&#xff0c;善行未来”为主题&#xff0c;围绕科技金融服务“向善”新生态&#xff0c;浙商银行重磅推出科创企业全图景服务方案&#xff0c;正式发布科创积分贷&#xff0c;与浙江大学联合发布人…

初冬天气变化大,长辈身上的这些小毛病千万不能轻视

心率、血氧、肺功能&#xff0c;甚至是一次次不起眼的咳嗽&#xff0c;背后都可能藏着健康问题。但是我们可以利用好手表上的健康检测功能&#xff0c;提前获知健康数据的变化&#xff0c;有的放矢&#xff0c;科学应对身体的不适&#xff0c;度过一个有准备的温暖冬天&#xf…

【JVM从入门到实战】(七)Java内存区域

运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域&#xff0c;称之为运行时数据区。 《Java虚拟机规范》中规定了每一部分的作用 线程不共享&#xff1a;程序计数器、虚拟机栈、本地方法栈 线程共享&#xff1a;方法区&#xff0c;堆 1. 程序计数器(Program Count…