深入理解React中es6创建组件this的方法


Posted in Javascript onAugust 29, 2016

首发于:https://mingjiezhang.github.io/。

在JavaScript中,this对象是运行时基于函数的执行环境(也就是上下文)绑定的。

从react中的demo说起

Facebook最近一次更新react时,将es6中的class加入了组件的创建方式当中。Facebook也推荐组件创建使用通过定义一个继承自 React.Component 的class来定义一个组件类。官方的demo:

class LikeButton extends React.Component {
constructor() {
super();
this.state = {
liked: false
};
this.handleClick = this.handleClick.bind(this);
}
handleClick() {
this.setState({liked: !this.state.liked});
}
render() {
const text = this.state.liked ? 'liked' : 'haven\'t liked';
return (
<div onClick={this.handleClick}>
You {text} this. Click to toggle.
</div>
);
}
}
ReactDOM.render(
<LikeButton />,
document.getElementById('example')
);

上面的demo中有大量this的使用,在 class LikeButton extends React.Component 中我们是声明该class,因为this具体是由其上下文决定的,因此在类定义中我们无法得知this用法。 相当于是new了上面定义的类,首先调用 constructor() 函数, this.state 的this上下文就是该实例对象;同理,render() 函数中 this.state.liked 的this上下文也是该对象。问题在于 onClick={this.handleClick} ,获取该函数引用是没有问题,这里的this上下文就是该对象。

这时问题来了,在原来 React.createClass 中, handleClick() 在onClick事件触发的时候,会自动绑定到LikeButton实例上,这时候该函数的this的上下文就是该实例。不过在ES6的class的写法中,Facebook取消了自动绑定,实例化LikeButton后,handleClick()的上下文是div的支撑实例( backing instance ),而 handleClick() 原本要绑定的上下文是LikeButton的实例。对于该问题,我们有多种解决方案。

使用bind()函数改变this的上下文

可以在class声明中的constructor()函数中,使用

this.handleClick = this.handleClick.bind(this);

该方法是一个bind()绑定,多次使用。在该方法中,我们在声明该实例后,可以在该实例任何地方使用 handleClick() 函数,并且该 handleClick() 函数的this的上下文都是LikeButton实例对象。

除此我们也可以在具体使用该函数的地方绑定this的上下文到LikeButton实例对象,代码如下

<div onClick={this.handleClick.bind(this)}>
You {text} this. Click to toggle.
</div>

这种方法需要我们每次使用bind()函数绑定到组件对象上。

es6的箭头函数

es6中新加入了箭头函数=>,箭头函数除了方便之外还有而一个特征就是将函数的this绑定到其定义时所在的上下文。这个特征也可以帮助我们解决这个问题。使用如下代码:

<div onClick={() => this.handleClick()}>
You {text} this. Click to toggle.
</div>

这样该 this.handleClick() 的上下文就会被绑定到LikeButton的实例对象上。个人认为,使用箭头函数使得JavaScript更加接近面向对象的编程风格。

this的总结

this的本质就是:this跟作用域无关的,只跟执行上下文有关。

以上所述是小编给大家介绍的React中es6创建组件this的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript Array扩展实现代码
Oct 14 Javascript
jQuery获取文本节点之 text()/val()/html() 方法区别
Mar 01 Javascript
JS window对象的top、parent、opener含义介绍
Dec 03 Javascript
JavaScript动态修改背景颜色的方法
Apr 16 Javascript
Javascript中的方法和匿名方法实例详解
Jun 13 Javascript
JavaScript与HTML的结合方法详解
Nov 23 Javascript
Vue.js组件使用开发实例教程
Nov 01 Javascript
JS文件/图片从电脑里面拖拽到浏览器上传文件/图片
Mar 08 Javascript
Angularjs中的$apply及优化使用详解
Jul 02 Javascript
详解js删除数组中的指定元素
Oct 31 Javascript
Node.js爬虫如何获取天气和每日问候详解
Aug 26 Javascript
解决Layui数据表格的宽高问题
Sep 28 Javascript
Ionic默认的Tabs模板使用实例
Aug 29 #Javascript
关于Javascript回调函数的一个妙用
Aug 29 #Javascript
Javascript学习之谈谈JS的全局变量跟局部变量(推荐)
Aug 28 #Javascript
利用jQuery的动画函数animate实现豌豆发射效果
Aug 28 #Javascript
教你如何在Node.js中使用jQuery
Aug 28 #Javascript
分享JavaScript监听全部Ajax请求事件的方法
Aug 28 #Javascript
Node.js 日志处理模块log4js
Aug 28 #Javascript
You might like
php 三维饼图的实现代码
2008/09/28 PHP
一个比较简单的PHP 分页分组类
2009/12/10 PHP
基于php设计模式中工厂模式详细介绍
2013/05/15 PHP
destoon利用Rewrite规则设置网站安全
2014/06/21 PHP
php获取textarea的值并处理回车换行的方法
2014/10/20 PHP
Js+XML 操作
2006/09/20 Javascript
解析dom中的children对象数组元素firstChild,lastChild的使用
2013/07/10 Javascript
javascript模拟地球旋转效果代码实例
2013/12/02 Javascript
js操作输入框提示信息且响应鼠标事件
2014/03/25 Javascript
jquery购物车结算功能实现方法
2020/10/29 Javascript
vue实现简单实时汇率计算功能
2017/01/15 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
2017/01/23 Javascript
angularjs中使用ng-bind-html和ng-include的实例
2017/04/28 Javascript
原生js实现简单的模态框示例
2017/09/08 Javascript
微信小程序返回多级页面的实现方法
2017/10/27 Javascript
利用jQuery+localStorage实现一个简易的计时器示例代码
2017/12/25 jQuery
详解ES6 Fetch API HTTP请求实用指南
2018/11/14 Javascript
jQuery子选择器与可见性选择器实例分析
2019/06/28 jQuery
微信小程序全选多选效果实现代码解析
2020/01/21 Javascript
vue单应用在ios系统中实现微信分享功能操作
2020/09/07 Javascript
Python将多个excel表格合并为一个表格
2021/02/22 Python
python中kmeans聚类实现代码
2018/02/23 Python
详谈python中冒号与逗号的区别
2018/04/18 Python
Python解析Excle文件中的数据方法
2018/10/23 Python
利用Python半自动化生成Nessus报告的方法
2019/03/19 Python
使用Python3 poplib模块删除服务器多天前的邮件实现代码
2020/04/24 Python
css3中背景尺寸background-size详解
2014/09/02 HTML / CSS
Application Cache未缓存文件无法访问无法加载问题
2014/05/31 HTML / CSS
惠普墨西哥官方商店:HP墨西哥
2016/12/01 全球购物
香港迪士尼乐园酒店预订:Hong Kong Disneyland Hotels
2017/05/02 全球购物
英国在线购买马术服装:EQUUS
2019/07/12 全球购物
毕业生求职信的经典写法
2014/01/31 职场文书
十佳美德少年事迹材料
2014/02/05 职场文书
2014小学植树节活动总结
2014/03/10 职场文书
销售团队获奖感言
2014/08/14 职场文书
解决 Redis 秒杀超卖场景的高并发
2022/04/12 Redis