高端前端彻底搞定this指向(详解)

news2024/11/19 15:17:51

这篇文章只告诉你三件事情,this,this,还TM的是this。

1,this在javascript中是可有可无的

大家在学习javascript的时候,肯定或多或少看到过了很多代码。其中肯定会发现this的身影。我们知道他是代表的指向,可是让人迷惑的是this的指向怎么这么善变呢?恰似你的女朋友。真是很深啊,我来教你从零了解你的女朋友。额,了解this。

var obj = {
  name: "zlk",
  foo() {
    console.log(this.name + " foo");
  },
  bar() {
    console.log(obj.name + " bar");
  }
}
    obj.bar()
    obj.foo()

发现了嘛,可有可无的this。一点卵用都没有,所以学不学的吧。但是这样做有一个很大的弊端:如果我将对象obj的名称换成了info,那么所有的方法中的obj都需要换成info。this就不需要换哦。

2,正儿八经讲this指向问题

this指向问题一共有四种不同,让我一一道来。

一,默认绑定

  • 该函数直接被调用,并没有进行任何的对象关联;
  • 这种独立的函数调用会使用默认绑定,通常默认绑定时,函数中的this指向全局对象(window);
function foo() {
  console.log(this); // window
}

foo();

所有的函数调用都没有被绑定到某个对象上;

// 2.案例二:
function test1() {
  console.log(this); // window
  test2();
}

function test2() {
  console.log(this); // window
  test3()
}

function test3() {
  console.log(this); // window
}
test1();

在真正函数调用的位置,并没有进行任何的对象绑定,只是一个独立函数的调用;我们不要常看this在哪里或者是this的环境,我们要看的是最终的调用位置,是什么形式调用的。

function foo(func) {
  func()
}

var obj = {
  name: "zlk",
  bar: function() {
    console.log(this); // window
  }
}

foo(obj.bar);

二,隐士绑定

  • foo的调用位置是obj.foo()方式进行调用的
  • 那么foo调用时this会隐式的被绑定到obj对象上
function foo() {
  console.log(this); // obj对象
}

var obj = {
  name: "zlk",
  foo: foo
}

obj.foo();
  • 我们通过obj2又引用了obj1对象,再通过obj1对象调用foo函数;
  • 那么foo调用的位置上其实还是obj1被绑定了this;
function foo() {
  console.log(this); // obj1对象
}

var obj1 = {
  name: "obj1",
  foo: foo
}

var obj2 = {
  name: "obj2",
  obj1: obj1
}

obj2.obj1.foo();

三,显示绑定

通过call或者apply绑定this对象

  • 显式绑定后,this就会明确的指向绑定的对象
function foo() {
  console.log(this);
}

foo.call(window); // window
foo.call({name: "zlk"}); // {name: "zlk"}
foo.call(123); // Number对象,存放时123

img

obj.myFun.call(db);    // 德玛年龄 99
obj.myFun.apply(db);    // 德玛年龄 99
obj.myFun.bind(db)();   // 德玛年龄 99

四,new绑定

JavaScript中的函数可以当做一个类的构造函数来使用,也就是使用new关键字。

使用new关键字来调用函数时,会执行如下的操作:

  • 1.创建一个全新的对象;
  • 2.这个新对象的隐士原型_ proto _会被赋值为这个函数的显示原型prototype;(如果不理解先跳过,不影响,下一章会讲原型与原型链的继承等)
  • 3.这个新对象会绑定到函数调用的this上(this的绑定在这个步骤完成);
  • 4.如果函数没有返回其他对象,表达式会返回这个新对象;
// 创建Person
function Person(name) {
  console.log(this); // 我们模拟出个对象Person {}
  this.name = name; // 这里的this会绑定到Person {} 讲外面的值传过来赋值后Person{name: "why"}
}

var p = new Person("why"); //我们在new一个构造函数的时候,这个函数会模拟出一个对象,返回后p接收了这个对象
console.log(p);
  • 绑定优先级

    默认规则的优先级最低

    显式绑定优先级高于隐式绑定

    new绑定优先级高于隐式绑定

    new绑定优先级高于bind

    new绑定 > 显式绑定(bind)> 隐式绑定 > 默认绑定

ES6箭头函数中this指向

在ES6中新增一个非常好用的函数类型:箭头函数

  • 这里不再具体介绍箭头函数的用法,可以自行学习。

箭头函数不使用this的四种标准规则(也就是不绑定this),而是根据外层作用域来决定this。意思就是箭头函数没有this指向这种说法,里面的this会指向上层作用域。这里有一点要注意的,无论你最终调用位置是什么方式,箭头函数的this都指向上层作用域。比如你call()自定义this指向。或者隐士绑定obj.foo()去调用的,这个this不指向call()你自定义的对象或方法,也不指向obj。它会指向箭头函数的上层作用域。

看个例子

这两段代码执行效果一样。

var obj = {
  data: [],
  getData: function() {
    var _this = this;
    setTimeout(function() {
      // 模拟获取到的数据
      var res = ["abc", "cba", "nba"];
      _this.data.push(...res);
    }, 1000);
  }
}

obj.getData();
var obj = {
  data: [],
  getData: function() {
    setTimeout(function() {
      // 模拟获取到的数据
      var res = ["abc", "cba", "nba"];
      this.data.push(...res);
    }, 1000);
  }
}

obj.getData();

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Scheduled定时任务异步执行

1.使用配置 我在使用SpringBoot配置定时任务的过程中,使用Scheduled配置了多个定时任务,但是在项目启动的时候每次只会启动一个定时任务,只好搜索一波,直到看到了 ThreadPoolTaskScheduler的源码,才发现默认开启的线程数是 1 Configuration public class ScheduledPoolConfi…

如何用代码实现决策树来决策要不要相亲?

前言 上一篇我们了解了什么是决策树,知道了决策树构建的过程,同时聊了构建决策树的两种算法,那么我们今天来看下如何使用代码实现决策树的构建。 数据分析整体流程 数据分析一般是以下的分析流程 1、加载数据集 首先我们构建数据,提供训…

windows10配置openvino

一、前言 gpu的常用部署我们是选择trt,那么cpu的部署呢?当然是英特尔的ov 这里要注意:我们一般是现在一台机器上利用exe(后续会说)安装完ov,那么以后在配好第一台软件配置后,以后部署到其他机器上只需要直接把dll和lib直接复制到另一台就可以运行了! 也就是说,只有…

Matplotlib学习笔记(第二章 2.11使用指南 一些简单的例子)

第二章 学习指南 本页包含更多使用Matplotlib的深入指南。它分为初级、中级和高级部分,以及涵盖特定主题的部分。 有关较短的示例,请参阅我们的示例页面。您还可以在我们的用户指南中找到外部资源和FAQ。 2.1介绍 这些教程涵盖了使用Matplotlib创建可…

P4设计实现链路监控

实验要求 在本次实验中,目的是编写一个P4程序,使主机能够监控网络中所有链路的使用情况本练习基于基本的IPv4转发练习,因此请确保在尝试此练习之前完成此练习(basic.p4)具体来说,我们将修改基本P4程序以处…

使用ChatGPT完成分类、检测、分割等计算机视觉任务(Pytorch)

前言 ChatGPT是一个由OpenAI训练的大型语言模型,其知识涵盖了很多领域。 虽然ChatGPT表示它不能用于写代码,但是万一是它太谦虚了呢? 下面的文字均为ChatGPT给出的回答。 使用ChatGPT解决图像分类任务 我们需要一个PyTorch模型&#xff0…

11-18-kafka-生产者理论

11-kafka-理论: Kafka 工作流程及文件存储机制 Kafka 工作流程 Kafka 中消息是以 topic 进行分类的,生产者生产消息,消费者消费消息,都是面向 topic的。 topic 是逻辑上的概念,而 partition 是物理上的概念&#xf…

【MySQL】MySQL数据库结构与操作

✨个人主页:bit me ✨当前专栏:MySQL数据库 ✨每日一语:自从厌倦于追寻,我已学会一觅即中,自从一股逆风袭来,我已能抗御八面来风,驾舟而行。 目 录 🌴一. 数据库介绍🌿1.…

工业物联网解决方案:地下水实时监测系统

地下水是水资源的重要组成部分,它具备水量稳定、水质好等特点,是农业灌溉、工矿和城市的重要水源之一,但同时也会出现沼泽化、地面沉降、滑坡等问题,影响当地自然环境和生活用水。 随着物联网通信技术的发展以及国家水资源管理的…

JavaScript (WebAPI)

目录 一、DOM 1. DOM树结构: 2. 重要概念 3. DOM 的工作流程 二、获取/操作元素 1. 获取 ① 获取单个元素 ② 获取所有元素 2. 操作 1. 获取/修改元素内容 3. 案例 三、新增元素 1. 创建元素节点 2. 插入节点到 DOM树 四、删除元素 一、DOM DOM 全…

Photoshop简单案例(8)——利用文字工具修改图片上文字

目录一、项目介绍二、原图上有要替换的文字2.1 方法1——利用修补工具修改2.2 方法2——利用移动工具(推荐)2.3 效果演示三、原图上没有要替换的文字一、项目介绍 本文介绍利用PhotoShop修改图片上的文字。修改下图图片中的学号。 二、原图上有要替换…

【HBU】2022秋线上作业-第五次-有关树的判断选择

判断题: 1. 一棵有124个结点的完全二叉树,其叶结点个数是确定的。 √ 高度为n的完全二叉树的结点数为2ⁿ-1 124位于64-1~128-1之间,所以这棵树的高度是7,前六层是满的有63个,第7层有124-6361个 64-613 第6层有…

使用Electron打包React项目

1、下载Electron Electron中文官网地址:https://www.electronjs.org/zh/docs/latest/ Electron下载如果单纯使用npm的话,会出现n多问题 所以建议使用国内的淘宝镜像 npm config set registry https://registry.npmmirror.com/然后下载 cnpm install -…

LeetCode 81. 搜索旋转排序数组 II

🌈🌈😄😄 欢迎来到茶色岛独家岛屿,本期将为大家揭晓LeetCode 81. 搜索旋转排序数组 II,做好准备了么,那么开始吧。 🌲🌲🐴🐴 一、题目名称 LeetC…

年后准备换工作的软件测试工程师们,你准备好了吗?

需要严肃说明的是:面试题库作为帮助大家准备面试的辅助资料,但是绝对不能作为备考唯一途径,因为面试是一个考察真实水平的,不是背会了答案就可以的,需要你透彻理解的,否则追问问题答不出来反而减分&#xf…

什么是dapp?如何在web中开发dapp?

web3 “Web3.0”是对“Web2.0”的改进,在此环境下,用户不必在不同中心化的平台创建多种身份,而是能打造一个去中心化的通用数字身份体系,通行各个平台。更像是一种概念吧。 区块链 区块链(Blockchain)是由…

54-64-k8s-集群监控-高可以用集群-交付部署

54-k8s-集群监控-高可以用集群-交付部署 k8s集群监控 1、概述 一个好的系统,主要监控以下内容 集群监控 节点资源利用率节点数运行Pods Pod监控 容器指标应用程序【程序占用多少CPU、内存】 2、监控平台 使用普罗米修斯【prometheus】 Grafana 搭建监控平台…

JS实现鼠标悬停变色

JS实现鼠标悬停变色 案例池子: JS实现鼠标悬停变色 JavaScript中的排他算法实现按钮单选 JavaScript中的localStorage JavaScript中的sessionStorage JavaScript实现网页关灯效果 JavaScript实现一段时间之后关闭广告 JavaScript实现按键快速获取输入框光标 …

第二证券|紧盯“有诺不行”隐疾 补齐上市公司高质量发展“短板”

有诺不可”的典型事例 “言而有信”是上市公司高质量开展的重要环节。近日,证监会印发的《推动提高上市公司质量三年举动计划(2022-2025)》(下称《举动计划》)提出,将着力处理管理领域杰出问题&#xff0c…

(Java)Thymeleaf学习笔记——动力节点

前言 学SpringMVC找课程时就了解到要学习thymeleaf这种Java模板引擎,但本着不用不学的原则就直接跳过,当实践第一个SpringMVC程序helloworld,遇见了thymeleaf,那么就先解决 💡thymeleaf 知识点,再来学习Sp…