在create-react-app创建的项目下允许函数绑定运算符
2024-09-02 03:25:26
前话
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} />
}
}
- stage 0 的 transform-function-bind
export default class CartItem extends React.Component {
method(){...};
render() {
<input type="button" value="点我" onClick={::this.method} />
}
}
最后一种很帅气, 然并软,我使用就直接报错。 臣不服,不服。
于是寻找方案, 因为是create-react-app创建的项目。
我的思考方案如下
- create-react-app内置支持的配置
在awesome-create-react-app中找到how-to-use-custom-babel-presets, 看到了光芒,光芒啊。
高兴太早,死的也早,Adding support for custom babel configuration被拒绝了,大致是,想法非常好,非常好,就是不能。那么,我走下一条路 - npm run eject
采用eject后,会多出很多文件,并且是不可逆向的。
恶心,恶心,那么多文件。我要出去透透气。 - react-app-rewired
这个比较简单一些。
寻寻觅觅找到了injectbabelplugin
然后找到对应的插件babel-preset-stage-0,babel-plugin-transform-function-bind
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
最新文章
- NodeJs 开发微信公众号(四)微信网页授权
- 【基于WPF+OneNote+Oracle的中文图片识别系统阶段总结】之篇二:基于OneNote难点突破和批量识别
- CentOS上安装spark standalone mode(转载)
- DataTable是否存在某个列的判断
- ARM基础知识
- 实验箱FPGA部分测试报告及A8与FPGA链接测试报告
- [STL] lower_bound和upper_bound
- dos基本命令
- java、myeclipse常见错误的解决(未完)
- 《University Calculus》-chape12-偏导数-基本概念
- inverse 相关设置
- Swift基础语法学习总结一
- #爬虫必备,解析html文档----beautifulsoup的简单用法
- 【Cocos2d-x游戏引擎开发笔记(25)】XML解析
- html文档知识补充
- js高级知识---词法分析和AO 链
- ceph使用对象网关
- 【奇淫技巧】API接口字段table文档转代码工具
- 《DISTRIBUTED SYSTEMS Concepts and Design》读书笔记 一
- java中使用相对路径读取文件的写法总结 ,以及getResourceAsStream() (转)
热门文章
- 使用Sed和Awk实现批量文件的文本替换
- consul 配置
- this指向 - Node环境
- Django加载静态网页模板
- kotlin 学习感受
- 使用SpringBoot发送邮件
- CAfile: /etc/ssl/certs/ca-certificates.crt CRLfile: none 解决方法
- /msgsrvmgr.cpp:4:26: fatal error: kdl/frames.hpp: No such file or directory #include <;kdl/frames.hpp>;
- install diagnostic_updater
- 计算机网络七层协议模型 “开放系统互联参考模型”,即著名的OSI/RM模型(Open System Interconnection/Reference Model)