iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >JavaScript中this的绑定规则是怎样的
  • 643
分享到

JavaScript中this的绑定规则是怎样的

2024-04-02 19:04:59 643人浏览 安东尼
摘要

javascript中this的绑定规则是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。对于 JavaScript 新手来说,this

javascript中this的绑定规则是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

对于 JavaScript 新手来说,this 是非常基础同时也难以理解的知识点。

比如下面的代码,this 指向就有三种方式。

function foo() {    console.log(this.a);  }  var a = 1;  var obj = { a: 2, foo: foo };  foo(); // 1  obj.foo(); // 2  foo.call({ a: 3 }); // 3

this 就是函数运行时所在的环境对象,它指向运行时所在的位置,而不是定义时的位置。

根据 this 绑定规则,分为下面四种:

  1.  默认绑定

  2.  隐式绑定

  3.  显式绑定

  4.  new 绑定

1. 默认绑定

默认情况下,this 指向全局对象。例如下面的代码。

var a = 2;  console.log(this.a); // 2  // 在函数中  function foo() {    console.log(this.a);  }  foo(); // 2  // 在回调函数中  function doFoo() {    return function() {      console.log(this.a);    };  }  doFoo()(); // 2

不过,函数在严格模式下,this 无法指向全局对象,因此this会绑定到undefined。

function foo() {    "use strict";    console.log(this);  }  foo(); // undefined

2. 隐式绑定

当函数作为方法被调用,需考虑运行时上下文环境。

function foo() {    console.log(this.a);  }  var obj = { a: 2, foo: foo };  obj.foo(); // 2

代码中,foo()前面添加了obj对象的修饰,因此,obj对象就是函数的上下文。

this 会绑定到这个对象上。

另外,需要注意下面三种情况,它们会出现绑定对象丢失,从而把this绑定到全局对象或undefined上。

情况一

这段代码中,虽然obj.foo()和bar()都指向同一函数,但执行结果并不一样。

可以理解为,bar()是一个不带任何修饰的函数调用,等价于直接调用foo(),因此应用了默认绑定。

function foo() {    console.log(this.a);  }  var a = 3;  var obj = { a: 2, foo: foo };  var bar = obj.foo;  obj.foo(); // 2  bar(); // 3

情况二

另一种情况,发生在回调函数中。原理和上面的情况一样。

修改上面的代码,obj.foo作为参数传入doFoo()函数中,实际上,引用的是foo()函数本身,因此应用了默认绑定。

function foo() {    console.log(this.a);  }  var a = 3;  var obj = { a: 2, foo: foo };  function doFoo(fn) {    return fn();  }  doFoo(obj.foo);  // 3

情况三

在一些流行的 JavaScript 库,进行事件处理操作时,回调函数的 this 可能会强制绑定到 DOM 元素上。

这种情况也值得注意。

3. 显式绑定

JavaScript 提供了call()、apply()和bind()方法,可以强制绑定函数的this对象。

function fn() {    console.log(this.a);  }  fn.call({ a: 3 }); // 3

通过fn.call(obj),我们将函数运行时,this强制绑定到obj上。

call apply和bind的区别

call 和 apply 改变了函数的 this 上下文后,便执行该函数,而 bind 则是将该函数返回。

function fn() {      console.log(this.a);  }  fn.call({ a: 3 }); // 3  fn.bind({ a: 4 })(); // 4

call和apply的区别

call 和 apply 的区别在于传入参数不同。

call 方法接收若干个参数列表。

apply 第一个参数和 call 一样,第二个参数接收一个包含多个参数的数组

let arr = [2, 5, 9]  console.log(Math.max.call(3, 2, 5, 9))  // 9  console.log(Math.max.call(3, arr))  // NaN  console.log(Math.max.apply(3, arr))  // 9

4. new 绑定

如果使用 new 构造函数,在函数内部,this 指向新创建的对象。

function foo() {    console.log(this);  }  new foo(); // foo {}  foo(); // Window {...}

其他情况

需要忽略的this

若第三方库的某个函数使用了 this,默认绑定会把this指向全局对象,从而导致不可预测的后果。

一个安全的做法,就是使用显式绑定,将函数的this指向空对象。

function foo() {    console.log(this);  }  // 创建空对象  var ø = Object.create(null);  // 使用bind()进行柯里化(Curry)  var bar = foo.bind(ø);  bar(); // {}

这方法通常也用于对象初始化,以获得一个干净且高度可定制的对象。

箭头函数

箭头函数常用于回调函数中。

它会继承父级作用域 this 绑定的对象,等价于es6之前self = this的书写方式。

const people = {      name: "Merry",      sayHi() {          console.log(this.name)      },      wait() {          setTimeout(() => {              console.log(this.name)          })      }  }  people.sayHi() // Merry  people.wait()  // Merry

此外还有软绑定(softBind),用的不多,了解一下即可。

看完上述内容,你们掌握JavaScript中this的绑定规则是怎样的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网VUE频道,感谢各位的阅读!

--结束END--

本文标题: JavaScript中this的绑定规则是怎样的

本文链接: https://www.lsjlt.com/news/82604.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中this的绑定规则是怎样的
    JavaScript中this的绑定规则是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。对于 JavaScript 新手来说,this ...
    99+
    2024-04-02
  • JavaScript 中的 this 绑定规则详解
    目录前言1. 关于 this 的简单介绍2. 为什么使用 this?3. 关于this 的常见的误解4. this 的绑定规则4.1 默认绑定4.2 隐式绑定4.3 显式绑定4.4 ...
    99+
    2023-02-14
    JavaScript中的this绑定规则 JavaScript中的this关键字 JS中this的4种绑定规则
  • JavaScript中 this 的绑定指向规则
    目录问题来源this 绑定规则1.默认绑定2.隐式绑定3.显示绑定4.new 绑定5.内置方法6.规则优先级7.规则之外8.实践问题来源 在 js 中,...
    99+
    2024-04-02
  • JavaScript中this有几种绑定规则
    这篇“JavaScript中this有几种绑定规则”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • 一文搞懂JavaScript中的this绑定规则
    目录前言  this四大绑定规则一.默认绑定二.隐式绑定三.new绑定四.显示绑定绑定规则优先级面试题题1题2题3题4前言  首先我们来看一个示例。定义...
    99+
    2024-04-02
  • JavaScript中this绑定规则的示例分析
    这篇文章主要介绍JavaScript中this绑定规则的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、this 的绑定规则this 一共有 4 中绑定规则,接下来一一介绍...
    99+
    2024-04-02
  • JavaScript中this的错误认识和绑定规则以及常见问题是怎样的
    JavaScript中this的错误认识和绑定规则以及常见问题是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。相信 Ja...
    99+
    2024-04-02
  • this的四个绑定规则是什么
    这篇文章主要介绍“this的四个绑定规则是什么”,在日常操作中,相信很多人在this的四个绑定规则是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”this的四个绑定规则是什么”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-04
  • 带你详解 this 的四个绑定规则
    实际上,JavaScript 中 this 的机制并没有那么先进,但是开发者往往会把理解过程复杂化, 毫无疑问,在缺乏清晰认识的情况下,this 对你来说完全就是一种魔法。2. 为什么使用 this?const obj = { titl...
    99+
    2022-11-22
    javascript this
  • 详解JavaScript中的this硬绑定
    目录一、this显示绑定二、硬绑定一、this显示绑定 this显示绑定,顾名思义,它有别于this的隐式绑定,而隐式绑定必须要求一个对象内部包含一个指向某个函数的属性(或者某个对象...
    99+
    2024-04-02
  • CSS中的规则声明是怎样的
    本篇文章给大家分享的是有关CSS中的规则声明是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  CSS 规则由 选择器 和 声...
    99+
    2024-04-02
  • JavaScript中this的绑定你知道几种?
    目录执行上下文this到底是什么呢调用位置绑定规则特例面试题执行上下文 我们知道执行上下文分为两种:全局上下文和函数上下文(我的这篇文章对于执行上下文有讲解还对执行上下文和作用域迷糊...
    99+
    2023-02-08
    JavaScript this绑定 JavaScript this
  • CSS中@规则语法是怎么样的
    小编给大家分享一下CSS中@规则语法是怎么样的,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! @规则语法@import&nbs...
    99+
    2024-04-02
  • Mycat分片规则是怎么样的
    Mycat分片规则是怎么样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 1.sharding-by-intfile hash分片表...
    99+
    2024-04-02
  • JavaScript中正则表达式是怎样的
    JavaScript中正则表达式是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。  好程序员web前端培训分享JavaScript学习笔...
    99+
    2024-04-02
  • 怎么理解Js的This绑定
    本篇内容主要讲解“怎么理解Js的This绑定”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解Js的This绑定”吧!js 的 this 绑定问题,让多数新...
    99+
    2024-04-02
  • javascript中原型对象this的原则是什么
    小编给大家分享一下javascript中原型对象this的原则是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!原则只有当调用这个函数时,才能确定构造函数中的this指向谁。一般来说,构造函数中的this指的是函数的调用...
    99+
    2023-06-20
  • React中this绑定的示例分析
    这篇文章主要介绍了React中this绑定的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 我们在re...
    99+
    2024-04-02
  • javascript中命名变量的规则是什么
    这篇“javascript中命名变量的规则是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这...
    99+
    2024-04-02
  • Gin框架中参数绑定的实现是怎样的
    Gin框架中参数绑定的实现是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。为了能够更方便的获取请求相关参数,提高开发效率,我们可以基于请求的Content...
    99+
    2023-06-22
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作