react-redux

对react-redux的connect方法进一步的封装

2018-12-04  本文已影响0人  lovinglili

不想每次用数据的时候写mapDispatchToProps,mapStateToProps 等这些重复的代码

关键代码

import { connect } from 'react-redux'
import { bindActionCreators } from 'redux'



const _connect = function (Uicomponent, reducers = [])  {

let mapStateToProps = (state) => {
    let result = {}
    // 如果没有传入reducer的名字,认为都想要
    if ( reducers.length <= 0 ) return state;
    
    reducers.forEach(reducer => {
        if (typeof reducer === 'string') {
            result[reducer] = state[reducer] ? state[reducer] : {}
        } else { // obj
            result[reducer.name] = filterObject(state[reducer.name], reducer.states)
        }
        
    })

    return result
}

let mapDispatchToProps = (dispatch) => {
    let result = {}
    // 如果没有传入reducer的名字,认为都想要
    if ( reducers.length <= 0 ) return {};
    if ( !_connect.actions ) return {};

    // 将对应的actionCreator的方法处理后传给UI组件
    reducers.forEach(reducer => {
        let name = (typeof reducer === 'string') ? reducer : reducer.name
        if ( !_connect.actions[name] ) return false;
        result[name + '_actions'] = bindActionCreators(_connect.actions[name], dispatch)
        
    })

    return result
}

return  connect(mapStateToProps, mapDispatchToProps)(Uicomponent)
}

  _connect.configActionCreators = function (actions) {
    _connect.actions = actions
}
_connect.addActionCreator = function (actionCreator) {

_connect.actions = { ...(_connect.actions || {}), ...actionCreator }
}

function filterObject (obj, arr) {
  if ( !arr || arr.length <= 0 ) return obj;
  let result = {}
  arr.forEach(key => {
    if ( obj.hasOwnProperty(key) ) {
        result[key] = obj[key]
    }     
})
return result
}


export default _connect

使用:

在引入connect的文件或者App.js文件里面添加你的action:如下:

import createAction from "../store/createActions"
connect.addActionCreator({
      main: createAction
  })
  //  main 代表一个数据模块,暴露出的一个reducer叫main;
//组件。。。Cal
export default connect(Cal,["main"])
//或
export default connect(Cal,[{name:'main',state:['count']}])

main模块

import {combineReducers } from "redux";
import main from "./reducer"
//可以引入多个,起名不冲突即可
const reducer=combineReducers({
    main
})

export default reducer;
上一篇 下一篇

猜你喜欢

热点阅读