绑定JavaScript的6种方法,在React,ES6和ES7中使用此关键字
密钥点
- > JavaScript的
this
关键字可能会令人困惑,尤其是在回调函数中。 在react,this
引用组件的上下文中,当功能上下文移动时可能会导致问题(例如,承诺回调)。 存在几种方法要管理 - 绑定:创建一个上级
this
参考(别名this),在运行时注入正确的上下文(绑定此),使用ES2015箭头功能,利用React组件方法,采用ES2016绑定语法(如果受支持),或使用接受显式this
参数的方法。this
> 最佳方法取决于诸如绩效,轻松易于调试和个人喜好之类的因素。 混叠 - 优先级;组件方法或命名函数改善调试;箭头函数对于简短的内联函数是简洁的。
this
>
关键字经常访问开发人员。与具有严格类模型的语言不同,其行为并不总是可以预测的,尤其是在呼叫站点无法控制的回调功能中。 外部代码可以使用this
>上的方法轻松地重新列出函数的上下文。这导致了不可预测的行为,通常会导致整个回调较重的代码中过度new
。 问题Function.prototype
.bind(this)
react的使用
引用组件上下文的使用继承了这种歧义。 考虑这种常见的反应模式:
this
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 }); });
此方法在运行时将正确的上下文注入回调:
指的是正确的对象。 但是,这种方法在深度嵌套的异步代码中变得笨拙,并且需要为每个功能进行手动绑定。
3。 React组件方法
>时自动绑定的方法。 这允许回升回调逻辑到组件:this
React.createClass
优雅的简单组件,这会促进清洁器代码并消除上下文问题。 请注意,此自动连接不适用于ES2015类;那里需要替代方法。 如果您不必要地
this.setState({ loading: true }); fetch('/').then(function loaded() { this.setState({ loading: false }); });
4。 ES2015箭头功能.bind(this)
)是简洁的,并从其封闭范围中继承 无论嵌套水平如何 缺点是函数命名的丢失,阻碍调试(堆栈跟踪显示“(匿名函数)”)。 Babel汇编通常使用这种方法来维持背景。
5。 ES2016绑定语法(提案)=>
this
>
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的性能,使用组件方法或命名功能调试易于易于调试,并在短内线代码中使用箭头函数简洁。 最佳选择取决于您的优先级和编码样式。 避免过度复杂的解决方案,以阻碍可读性和可维护性。
this
map
常见问题(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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务
