深入理解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 Event学习第八章 事件的顺序
Feb 07 Javascript
js中根据字数截取字符串,不能截断url
Jan 12 Javascript
JS/Jquery判断对象为空的方法
Jun 11 Javascript
JavaScript实现获得所有兄弟节点的方法
Jul 23 Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
Dec 14 Javascript
详解用webpack把我们的业务模块分开打包的方法
Jul 20 Javascript
解决IE7中使用jQuery动态操作name问题
Aug 28 jQuery
详解React Native顶|底部导航使用小技巧
Sep 14 Javascript
在 React、Vue项目中使用SVG的方法
Feb 09 Javascript
vue+element-ui+axios实现图片上传
Aug 20 Javascript
原生javascript运动函数的封装示例【匀速、抛物线、多属性的运动等】
Feb 23 Javascript
VUE使用draggable实现组件拖拽
Apr 06 Vue.js
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
mysql下创建字段并设置主键的php代码
2010/05/16 PHP
php中serialize序列化与json性能测试的示例分析
2013/04/27 PHP
php另类上传图片的方法(PHP用Socket上传图片)
2013/10/30 PHP
PHP实现按之字形顺序打印二叉树的方法
2018/01/16 PHP
PhpStorm2020 + phpstudyV8 +XDebug的教程详解
2020/09/17 PHP
深入理解JS中的变量及作用域、undefined与null
2014/03/04 Javascript
纯JS实现根据CSS的class选择DOM
2014/03/22 Javascript
自己封装的javascript事件队列函数版
2014/06/12 Javascript
JS与Ajax Get和Post在使用上的区别实例详解
2016/06/08 Javascript
HTML5 js实现拖拉上传文件功能
2020/11/20 Javascript
详解vue-router 2.0 常用基础知识点之router.push()
2017/05/10 Javascript
vue.js图片转Base64上传图片并预览的实现方法
2018/08/02 Javascript
React SSR样式及SEO的实践
2018/10/22 Javascript
微信小程序 调用微信授权窗口相关问题解决
2019/07/25 Javascript
JS实现水平遍历和嵌套递归操作示例
2019/08/15 Javascript
微信小程序实现手势滑动卡片效果
2019/08/26 Javascript
ElementUI之Message功能拓展详解
2019/10/18 Javascript
VSCode搭建React Native环境
2020/05/07 Javascript
Vue3.0的优化总结
2020/10/16 Javascript
Python3.6安装及引入Requests库的实现方法
2018/01/24 Python
详解Python中正则匹配TAB及空格的小技巧
2019/07/26 Python
python Matplotlib底图中鼠标滑过显示隐藏内容的实例代码
2019/07/31 Python
python递归下载文件夹下所有文件
2019/08/31 Python
python实现画出e指数函数的图像
2019/11/21 Python
Python私有属性私有方法应用实例解析
2020/09/15 Python
Numpy中np.max的用法及np.maximum区别
2020/11/27 Python
Python爬取某平台短视频的方法
2021/02/08 Python
计算机专业大学生的自我评价
2013/11/14 职场文书
中专生职业生涯规划书范文
2013/12/29 职场文书
《他得的红圈圈最多》教学反思
2014/04/24 职场文书
住院医师规范化培训实施方案
2014/06/12 职场文书
数学教研活动总结
2014/07/02 职场文书
关键在于落实心得体会
2014/09/03 职场文书
巾帼文明岗事迹材料
2014/12/24 职场文书
台风停课通知
2015/04/24 职场文书
党校团干班培训心得体会
2016/01/06 职场文书