react-redux

下載安裝

npm install react-redux redux --save

概念:

Provider組件:自動的將store的state和組件進行關(guān)聯(lián)
mapState:這個函數(shù)用于將store的state映射到組件的props
mapActions:將store中的dispatch映射到props里,實現(xiàn)了數(shù)據(jù)的共享
connect方法:將組件和數(shù)據(jù)(方法)進行連接

項目目錄下src/redux/store

import {createStore} from 'redux';

// 初始化數(shù)據(jù)
const intialState={
    num:1
}

let  actions={
    add:(state,action)=>{
        state.num++;
        return state
    },
    decrement:(state,action)=>{
        state.num--;
        return state
    }
}
// 通過動作,創(chuàng)建新的state
const reducer=(state={    //state的默認值
    ...intialState
},action)=>{              //通過調(diào)用store.dispatch({type:'add'})斯议,可使state.num自增
    console.log(action)
    // switch (action.type){
    //     case 'add':
    //         state.num++;
    //         break;
    //     case 'decrement':
    //         state.num--;
    //         break;
    //     default:
    //         break;
    // }
    // 這里是簡化switch的寫法巩掺,在上面的actions里面定義修改數(shù)據(jù)的動作會更加直觀明了
    let type=action.type
    let keys=Object.keys(actions);
    if(keys.indexOf(type)>=0){
        state=actions[type](state,action)
    }
   
    // 返回一個新的對象(修改過后的)
    return {...state};   //舊版本
    // return state   //新版本
}
// 將mapState和mapActions映射到組件的props上面
export const mapState=(state)=>{
    return {
       ...state
    }
}
export const mapActions=(dispatch)=>{
    let keys=Object.keys(actions);
    console.log(keys)
    let obj={}
    for(let index=0;index<keys.length;index++){
        obj[keys[index]]=()=>{dispatch({type:keys[index]})}
    }
    return obj
    // 上面的方法是用于簡化下面的方法,不用每次寫一個action续膳,就往return的對象里添加一個方法去dispatch動作
    // return{
    //     add:()=>{dispatch({type:'add'})}
    // }
}


// 創(chuàng)建倉庫
export const store=createStore(reducer)

項目目錄下src/index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';

import {Provider} from 'react-redux';
import {store} from './redux/store'

ReactDOM.render(
  <Provider store={store}>
    <React.StrictMode>
    <App />
  </React.StrictMode>
  </Provider>,
  document.getElementById('root')
);
reportWebVitals();

頁面(組件)使用

import React from 'react';
// import store from '../Redux'
import {mapActions,mapState} from '../Redux/reactRedux';
import {connect} from 'react-redux'
const App = (props) => {
    //intialState和actions里的內(nèi)容就被整合到了props里
    return (
        <div>
            <p>{props.num}</p>
            <button onClick={()=>{props.add()}}>加</button>
        </div>
    );
}
//connect方法:將組件和數(shù)據(jù)(方法)進行連接
export default connect(mapState,mapActions)(App);

個人覺得redux比react-redux要簡單好用些

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末改艇,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子坟岔,更是在濱河造成了極大的恐慌谒兄,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件社付,死亡現(xiàn)場離奇詭異承疲,居然都是意外死亡,警方通過查閱死者的電腦和手機鸥咖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門燕鸽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人啼辣,你說我怎么就攤上這事啊研。” “怎么了熙兔?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵悲伶,是天一觀的道長。 經(jīng)常有香客問我住涉,道長麸锉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任舆声,我火速辦了婚禮花沉,結(jié)果婚禮上柳爽,老公的妹妹穿的比我還像新娘。我一直安慰自己碱屁,他們只是感情好磷脯,可當我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著娩脾,像睡著了一般赵誓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上柿赊,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天俩功,我揣著相機與錄音,去河邊找鬼碰声。 笑死诡蜓,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的胰挑。 我是一名探鬼主播蔓罚,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瞻颂!你這毒婦竟也來了豺谈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤蘸朋,失蹤者是張志新(化名)和其女友劉穎核无,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體藕坯,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡团南,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了炼彪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吐根。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖辐马,靈堂內(nèi)的尸體忽然破棺而出拷橘,到底是詐尸還是另有隱情,我是刑警寧澤喜爷,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布冗疮,位于F島的核電站,受9級特大地震影響檩帐,放射性物質(zhì)發(fā)生泄漏术幔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一湃密、第九天 我趴在偏房一處隱蔽的房頂上張望诅挑。 院中可真熱鬧四敞,春花似錦、人聲如沸拔妥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽没龙。三九已至铺厨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間兜畸,已是汗流浹背努释。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留咬摇,地道東北人。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓煞躬,卻偏偏與公主長得像肛鹏,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子恩沛,可洞房花燭夜當晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容