在 React 组件中,每个方法的上下文都会指向该组件的实例,即自动绑定 this 为当前组件。 而且 React 还会对这种引用进行缓存,以达到 CPU 和内存的优化。在使用 ES6 classes 或者纯 函数时,这种自动绑定就不复存在了,我们需要手动实现 this 的绑定。

1.bind方法进行绑定,这个方法可以帮助我们绑定事件处理器内的 this ,并可以向事件处理器中传 递参数,如下图清晰明了:

bind方法绑定

2.箭头函数进行绑定,箭头函数不仅是函数的“语法糖”,它还自动绑定了定义此函数作用域的 this, 因此我们不需要再对它使用 bind 方法如下图:

箭头函数1

也可以是下面这种:

class App extends Component {

handleClick(e) { console.log(e); }

render() {return <button onClick={() => this.handleClick()}>Test</button>}

}

3.构造器内声明。在组件的构造器内完成了 this 的绑定,这种绑定方式的好处在于仅需要 进行一次绑定,而不需要每次调用事件监听器时去执行绑定操作

构造器内声明

以上就是三种事件绑定的方式,我个人觉得第三种比较好,只需要进行一次绑定操作优化性能。

最后附上一张渲染报错的例子如下:

Warning: Cannot update during an existing state transition (such as within `render`). Render methods should be a pure function of props and state

出现如上的提示说明事件并没有绑定到this实例上,按上述三种方式解决即可!!!

本人才疏学浅,有不对的地方请多多指教,共同进步!!!

最新文章

  1. 《Entity Framework 6 Recipes》中文翻译系列 (45) ------ 第八章 POCO之获取原始对象与手工同步对象图和变化跟踪器
  2. Android开发2:事件处理及实现简单的对话框(Toast,AlertDialog,Snackbar,TextInputLayout的使用)
  3. Android APP 读取 AndroidManifest.xml 中的版本信息详解
  4. 本BLOG简介(内有一道UVa524素数环进阶版)【B001】
  5. sublime使用
  6. IE css expression(表达式)
  7. CMake实践(2)
  8. CSS 基本知识
  9. Reactor模型
  10. Windows 下统计行数的命令
  11. 用js实现算法:冒泡排序、插入排序和快速排序
  12. awk 计算某一列的和
  13. c/c++再学习:查找算法了解
  14. VMware复制CentOS7,网络配置问题处理
  15. Tomcat启动分析(转自:http://docs.huihoo.com/apache/tomcat/heavyz/01-startup.html)
  16. vue事件深入
  17. Qt的pro文件--项目配置的部分字段
  18. iOS开发-带Placeholder的UITextView实现
  19. 50 Jquery 库
  20. cocos2d-x中用到的一些宏

热门文章

  1. Murano Weekly Meeting 2016.07.05
  2. JavaScript Date学习实例:获取3分钟前的时间“hhmmss”格式
  3. Cannot convert value &#39;0000-00-00 00:00:00&#39; from column 1 to TIMESTAMP解决办法
  4. 【frame】找上一层
  5. Unity C# 使用JsonUtility读写Json文件
  6. 使用ajax获取用户所在地的天气
  7. [Java][Liferay] 如何从Javascript的function中获取language property的值
  8. 在GitHub,他们是怎么玩的? (转)
  9. js实现弹幕效果
  10. Andoid Intent学习之在各个活动之间传递数据