react-redux

Provider:根组件
当前整个项目都在Provider下,作用是可以让store可以供内部任何组件使用(基于上下文完成的),Provider下只能存在一个子元素

import store from './store';
import { Provider} from 'react-redux';
ReactDOM.render(<Provider store={store}>
  <MyRouter />
  </Provider>, document.getElementById('root'));

子组件和redux创建连接需要用到react-redux的connect方法

当你需要在此组件上挂载action方法和reducer中的数据那么久用connect方法
connect(state => ({ ...state.user }), action.user)(Form.create()(AddUser))第一个参数是你需要挂载的reducer,第二个参数是你要挂载的action方法,action被封装成了一个对象,在挂载时需要返回的是对象中的方法,直接挂载对象是无法生效的。比如action中封装的是方法那你可以直接使用action,假如action对象中封装的是对象那么你需要用action.对象取出对象中的方法才能挂载生效,在使用时我们可以在this.props中看到我们挂载的数据和方法

import { connect } from 'react-redux';
import action from '../../store/action'
//=>把redux容器中的状态信息遍历,赋值给当前组件的属性
let mapStateToProps = state => {
    // 需要用到什么就返回什么,把它挂载到当前组件的属性上
    return{
        ...state.user
    }
};
//=>把redux中的dispatch派发行为遍历,也赋值给组件的属性
let mapDispatchToProps = dispatch => {
    return {
        init(initData){
            dispatch(action.user.init(initData))
        }
    }
}

export default connect([mapStateToProps], [mapDispatchToProps])(Form.create()(AddUser));
export default connect(state => ({ ...state.user }), action.user)(Form.create()(AddUser));//简写上面的步骤

当需要redux处理异步请求需要使用中间件redux-thunk再创建store的时候

import { createStore, applyMiddleware, compose } from 'redux';
import reducer from './reducer';
import thunk from 'redux-thunk';
let store = createStore(
    reducer,
    applyMiddleware(thunk)
);
export default store; 

当需要在浏览器上使用redux插件调试

import { createStore, applyMiddleware, compose } from 'redux';
import reducer from './reducer';
import thunk from 'redux-thunk';

const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;
let store = createStore(
    reducer,
    composeEnhancers(applyMiddleware(thunk))
);

export default store; 

一个完成的react-redux流程

store => action-types.js
    export const ADD_USER_ALL = 'ADD_USER_ALL' //创建一个派发行为
======================================================
action => user.js
    import * as TYPES from '../action-types';//引入行为列表
    import {userSeekAll} from '../../api/request';//引入ajax请求列表
    const user = {//user为一个普通对象,存放的方法都是基于以后对user相关的操作
        userSeekAll(){//创建一个获取用户的方法
              return async dispatch => {//因为用到了ajax异步操作需要使用async ,await
                        let userList = await  userSeekAll();//等待执行完成引入的ajax请求函数返回结果后再执行下面步骤,把请求到的数据给变量userList
                        dispatch({//最后把dispatch返回给userSeekAll,当执行userSeekAll()时就开始了派发任务
                           type: TYPES.ADD_USER_ALL,
                           userList
                        })
              }
        }
    }
action => index.js  //合并所有action
  import user from './user.js';
  const action = {
    uesr
  }
export default action;
======================================================
reducer => user.js //管理user状态的容器
import * as TYPES from '../action-types.js';
export default function user(state = {} ,action){//user容器的初始state给了默认值为空对象,action是派发的时候给的参数
     state = JSON.parse(JSON.stringify(state));//不能直接更改原有state,需要深拷贝一份来更改或者用解构赋值拷贝 state = {...state}
      switch (action.type) {//判断是哪个派发行为
        case TYPES.ADD_USER_ALL:
            state.userList = action.userList//把派发行为的值赋值给state
            break;
        default:
            break;
      }
     return state;//最后把state返回
 }
======================================================
reducer => index.js//把每个模块的单独设定的reducer函数最后合并成为总的reducer
import user from './user';
import { combineReducers } from 'redux';//combineReducers为redux提供的合并reducer的方法
let reducer = combineReducers({
    user
})
export default reducer;
======================================================
store => index.js//最后创建store容器
import { createStore, applyMiddleware, compose } from 'redux';
import reducer from './reducer';
import thunk from 'redux-thunk';

const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose;
let store = createStore(
    reducer,
    composeEnhancers(applyMiddleware(thunk))
);

export default store; 
======================================================
最后在根目录的index.js中引入
import store from './store';
import { Provider} from 'react-redux';
ReactDOM.render(
  <Provider store={store}>
    <App />
  </Provider>, document.getElementById('root'));
在子组件中
import { connect } from 'react-redux';
import action from '../../store/action'
export default connect(state => ({ ...state.user }), action.user)(Form.create()(AddUser));
//state => ({ ...state.user })将user中的状态挂载到当前组件
//action中的user方法挂载到当前组件

注(数据已更新,视图未更新的原因一般都是在reducer中没有克隆state,直接改变了原有state导致视图不正常更新)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容