前话

React的函数绑定一致是个问题,主要有下面几种方式:

  • 事件处理器动态绑定
export default class Com extends React.Component {
render() {
<input type="button" value="点我" onClick={this.method.bind(this)} />
}
}
  • 构造函数绑定
export default class CartItem extends React.Component {

    constructor(props) {
super(props);
this.method = this.method.bind(this);
} render() {
<input type="button" value="点我" onClick={this.method} />
}
}
  • 构造函数 + 箭头函数 | 箭头函数
export default class CartItem extends React.Component {

    const method2 = () =>{...}

    constructor(props) {
super(props);
this.method = (ev) => {...}
} render() {
<input type="button" value="点我" onClick={this.method} />
}
}

这个是babel支持的,还不是标准

export default class CartItem extends React.Component {

    method = () => {...};

    render() {
<input type="button" value="点我" onClick={this.method} />
}
}

export default class CartItem extends React.Component { method(){...}; render() {
<input type="button" value="点我" onClick={::this.method} />
}
}

最后一种很帅气, 然并软,我使用就直接报错。 臣不服,不服。

于是寻找方案, 因为是create-react-app创建的项目。

我的思考方案如下

const rewireMobX = require('react-app-rewire-mobx');
const rewireEslint = require('react-app-rewire-eslint');
const {injectBabelPlugin} = require('react-app-rewired'); /* config-overrides.js */
module.exports = {
webpack: function override(config, env) {
config = rewireEslint(config, env);
config = rewireMobX(config, env);
config = injectBabelPlugin('transform-function-bind',config) config.output.publicPath = ''
return config;
}
}

修改完毕,启动,哦,可以。 真是不错。

扔掉键盘,甩开鼠标,深深的一口水,想写行代码咋这么难。

React and ES6 - Part 3, Binding to methods of React class (ES7 included)

decorator

create-react-app

how-to-use-custom-babel-presets

Adding support for custom babel configuration #1357

react-app-rewired

injectbabelplugin

babel-preset-stage-0

babel-plugin-transform-function-bind

最新文章

  1. NodeJs 开发微信公众号(四)微信网页授权
  2. 【基于WPF+OneNote+Oracle的中文图片识别系统阶段总结】之篇二:基于OneNote难点突破和批量识别
  3. CentOS上安装spark standalone mode(转载)
  4. DataTable是否存在某个列的判断
  5. ARM基础知识
  6. 实验箱FPGA部分测试报告及A8与FPGA链接测试报告
  7. [STL] lower_bound和upper_bound
  8. dos基本命令
  9. java、myeclipse常见错误的解决(未完)
  10. 《University Calculus》-chape12-偏导数-基本概念
  11. inverse 相关设置
  12. Swift基础语法学习总结一
  13. #爬虫必备,解析html文档----beautifulsoup的简单用法
  14. 【Cocos2d-x游戏引擎开发笔记(25)】XML解析
  15. html文档知识补充
  16. js高级知识---词法分析和AO 链
  17. ceph使用对象网关
  18. 【奇淫技巧】API接口字段table文档转代码工具
  19. 《DISTRIBUTED SYSTEMS Concepts and Design》读书笔记 一
  20. java中使用相对路径读取文件的写法总结 ,以及getResourceAsStream() (转)

热门文章

  1. 使用Sed和Awk实现批量文件的文本替换
  2. consul 配置
  3. this指向 - Node环境
  4. Django加载静态网页模板
  5. kotlin 学习感受
  6. 使用SpringBoot发送邮件
  7. CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile: none 解决方法
  8. /msgsrvmgr.cpp:4:26: fatal error: kdl/frames.hpp: No such file or directory #include &lt;kdl/frames.hpp&gt;
  9. install diagnostic_updater
  10. 计算机网络七层协议模型 “开放系统互联参考模型”,即著名的OSI/RM模型(Open System Interconnection/Reference Model)