码迷,mamicode.com
首页 > 其他好文 > 详细

在react中用装饰器来装饰connect

时间:2018-12-21 22:51:21      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:问题   err   pos   ops   babel   性问题   定义   nec   todo   

假设我们在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了

来源:https://segmentfault.com/a/1190000017338904

在react中用装饰器来装饰connect

标签:问题   err   pos   ops   babel   性问题   定义   nec   todo   

原文地址:https://www.cnblogs.com/datiangou/p/10158912.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!