搜索
首页web前端js教程绑定JavaScript的6种方法,在React,ES6和ES7中使用此关键字

6 Ways to Bind JavaScript's this Keyword in React, ES6 & ES7

密钥点

  • > JavaScript的this关键字可能会令人困惑,尤其是在回调函数中。 在react,this引用组件的上下文中,当功能上下文移动时可能会导致问题(例如,承诺回调)。
  • 存在几种方法要管理
  • 绑定:创建一个上级this参考(别名this),在运行时注入正确的上下文(绑定此),使用ES2015箭头功能,利用React组件方法,采用ES2016绑定语法(如果受支持),或使用接受显式this参数的方法。this>
  • 最佳方法取决于诸如绩效,轻松易于调试和个人喜好之类的因素。 混叠
  • 优先级;组件方法或命名函数改善调试;箭头函数对于简短的内联函数是简洁的。this>
> JavaScript的

关键字经常访问开发人员。与具有严格类模型的语言不同,其行为并不总是可以预测的,尤其是在呼叫站点无法控制的回调功能中。 外部代码可以使用this>上的方法轻松地重新列出函数的上下文。这导致了不可预测的行为,通常会导致整个回调较重的代码中过度new。 问题Function.prototype .bind(this)react的使用

引用组件上下文的使用继承了这种歧义。 考虑这种常见的反应模式:

this

这会产生a
this.setState({ loading: true });

fetch('/').then(function loaded() {
  this.setState({ loading: false });
});
,因为

不是函数。承诺回调改变了函数的内部上下文,导致TypeError引用错误的对象。让我们探索解决方案。 解决方案this.setState this这些解决方案范围从已建立的JavaScript技术到反应特异性方法和更新的(潜在不支持的)特征。

1。别名这个

>一种长期的方法涉及在组件的顶级创建第二个参考:

>简单且容易理解,这为正确的上下文提供了明确的视觉保证。虽然看似违反直觉,但它是有效而直接的。this>

const component = this;
component.setState({ loading: true });

fetch('/').then(function loaded() {
  component.setState({ loading: false });
});
2。绑定此

此方法在运行时将正确的上下文注入回调:> >每个JavaScript函数都有一个指定

的方法。 一旦绑定,上下文就无法覆盖,确保

指的是正确的对象。 但是,这种方法在深度嵌套的异步代码中变得笨拙,并且需要为每个功能进行手动绑定。

3。 React组件方法

React组件允许定义使用

>时自动绑定的方法。 这允许回升回调逻辑到组件:> this React.createClass优雅的简单组件,这会促进清洁器代码并消除上下文问题。 请注意,此自动连接不适用于ES2015类;那里需要替代方法。 如果您不必要地

对组件方法,React会警告您。
this.setState({ loading: true });

fetch('/').then(function loaded() {
  this.setState({ loading: false });
});
>

4。 ES2015箭头功能.bind(this)

> es2015箭头函数(

)是简洁的,并从其封闭范围中继承 无论嵌套水平如何 缺点是函数命名的丢失,阻碍调试(堆栈跟踪显示“(匿名函数)”)。 Babel汇编通常使用这种方法来维持背景。

5。 ES2016绑定语法(提案)=>this>

提出的ES2016(ES7)绑定语法使用将函数绑定到给定的
const component = this;
component.setState({ loading: true });

fetch('/').then(function loaded() {
  component.setState({ loading: false });
});
>值。 例如:

this

虽然很有趣,但该语法并未得到广泛支持,并且遭受了与

>的类似缺点,通常会汇编为相同的结果。> 6。特定于方法的方法

某些功能允许传递显式::参数(例如,this的最终参数):>

this.setState({ loading: true });

fetch('/').then(function loaded() {
  this.setState({ loading: false });
}.bind(this));
这是不一致的;大多数功能都缺乏此功能。

.bind(this)

结论

有多种方法来管理

上下文。 优先使用Alias的性能,使用组件方法或命名功能调试易于易于调试,并在短内线代码中使用箭头函数简洁。 最佳选择取决于您的优先级和编码样式。 避免过度复杂的解决方案,以阻碍可读性和可维护性。

thismap常见问题(FAQS)

React.createClass({
  componentWillMount: function() {
    this.setState({ loading: true });
    fetch('/').then(this.loaded);
  },
  loaded: function loaded() {
    this.setState({ loading: false });
  }
});
>

>(为简洁而省略了常见问题,因为它们在很大程度上涵盖了原始文本,并且会大大增加这种已经全面的响应的长度。原始常见问题解答很好地覆盖了此主题。 >

以上是绑定JavaScript的6种方法,在React,ES6和ES7中使用此关键字的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在JavaScript中替换字符串字符在JavaScript中替换字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

自定义Google搜索API设置教程自定义Google搜索API设置教程Mar 04, 2025 am 01:06 AM

本教程向您展示了如何将自定义的Google搜索API集成到您的博客或网站中,提供了比标准WordPress主题搜索功能更精致的搜索体验。 令人惊讶的是简单!您将能够将搜索限制为Y

8令人惊叹的jQuery页面布局插件8令人惊叹的jQuery页面布局插件Mar 06, 2025 am 12:48 AM

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

构建您自己的Ajax Web应用程序构建您自己的Ajax Web应用程序Mar 09, 2025 am 12:11 AM

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

什么是这个'在JavaScript?什么是这个'在JavaScript?Mar 04, 2025 am 01:15 AM

核心要点 JavaScript 中的 this 通常指代“拥有”该方法的对象,但具体取决于函数的调用方式。 没有当前对象时,this 指代全局对象。在 Web 浏览器中,它由 window 表示。 调用函数时,this 保持全局对象;但调用对象构造函数或其任何方法时,this 指代对象的实例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。这些方法使用给定的 this 值和参数调用函数。 JavaScript 是一门优秀的编程语言。几年前,这句话可

10张移动秘籍用于移动开发10张移动秘籍用于移动开发Mar 05, 2025 am 12:43 AM

该帖子编写了有用的作弊表,参考指南,快速食谱以及用于Android,BlackBerry和iPhone应用程序开发的代码片段。 没有开发人员应该没有他们! 触摸手势参考指南(PDF) Desig的宝贵资源

通过来源查看器提高您的jQuery知识通过来源查看器提高您的jQuery知识Mar 05, 2025 am 12:54 AM

jQuery是一个很棒的JavaScript框架。但是,与任何图书馆一样,有时有必要在引擎盖下发现发生了什么。也许是因为您正在追踪一个错误,或者只是对jQuery如何实现特定UI感到好奇

如何创建和发布自己的JavaScript库?如何创建和发布自己的JavaScript库?Mar 18, 2025 pm 03:12 PM

文章讨论了创建,发布和维护JavaScript库,专注于计划,开发,测试,文档和促销策略。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

仓库:如何复兴队友
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。