在react中用装饰器来装饰connect

发布时间:2019-06-20 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了在react中用装饰器来装饰connect脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

假设我们在react中有如下header组件:

import React, { PureComponent } from 'react';
import { connect } from 'react-redux';
import actions from './actions';
class Header extends PureComponent{
  render(){
    return (
      <div>这是个组件</div>
    )
  }
}

const mapStateToProps = state => ({
  todos:state.todos
})

const mapDispatchToProps = dispatch => ({
  setTodos:value=>dispatch(actions.setTodos(value))
})

export default connect(mapStateToProps,mapDispatchToProps)(Header)

我们在写react组件时结合redux要定义mapStateToProps和mapDispatchToProps两个返回对象的纯函数以便交给connect去包裹使用 具体connect使用查看connect

这里我们就可以用装饰器(Decorator)来改写下:

import React, { PureComponent } from 'react';
import { connect } from 'react-redux';
import actions from './actions';

@connect(
  state=>({
    todos:state.todos
  }),
  dispatch=>({
    setTodos:value=>dispatch(actions.setTodos(value))
  })
)
class Header extends PureComponent{
  render(){
    return (
      <div>这是个组件</div>
    )
  }
}

export default Header

如此,改造完成,代码看上去也比改造前的干净整洁了

但是由于装饰器的兼容性问题我们需要使用babel来转换

// 安装babel插件
yarn add @babel/plugin-proposal-decorators

修改package.json下的babel

"babel": {
  "presets": [
    "react-app"
  ],
  "plugins": [
    [
      "@babel/plugin-proposal-decorators",
      {
        "legacy": true
      }
    ]
  ]
},

最后一步
根目录下新建jsconfig.json解决编辑器报错问题

{
  "compilerOptions": {
    "experimentalDecorators": true
  }
}

然后就可以愉快的coding了

脚本宝典总结

以上是脚本宝典为你收集整理的在react中用装饰器来装饰connect全部内容,希望文章能够帮你解决在react中用装饰器来装饰connect所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: