react-redux 和 redux

首先 npm install react-redux 和 npm install redux
新建store文件夾再建 index.js文件

/** @format */

import { createStore } from 'redux';
import reducer from './reducer';

const store = createStore(reducer);

export default store;

新建reducer.js 文件

export default (state = '', { type, payload }) => {
  switch (type) {
    // 登錄,設(shè)置權(quán)限,和登錄態(tài)
    case 'LOGIN':
      return { ...state, ...payload, isLogin: true, };
  // 登出,
    case 'LOGOUT':
      return { ...state, ...payload,isLogin: false,  };

    default:
      return state;
  }
};

在根目錄引用

import { Provider, useDispatch, useSelector } from 'react-redux';
import store from './store/index';
const App = () => {
const dispatch = useDispatch();
 //登錄
  const login= useCallback(async (val) => {
    try{
      const { userName, pwd } = val;
       // 調(diào)用的登錄接口
      const resp = await login({
        username: userName,
        password: md5(pwd),
      });
      resp && dispatch({
        type: 'LOGIN',
        payload: resp,
      });
    }catch(e){
      message.error({ content: e.response.data.message });
    }
   
  }, [dispatch,login]);
  // 登出
  const logout = useCallback(async () => {
   // 調(diào)用的登出接口
    await fetchLogout();
    dispatch({ type: 'LOGOUT' });
  }, [dispatch, fetchLogout]);
  return (
    <Provider store={store}>
        {/* 包裹全部組件 */}
           <Home/>
    </Provider>
  );
  );  
};

然后在Home組件可以通過store.getState()獲取登錄的一些數(shù)據(jù)

import React, { useCallback, useEffect, useState } from "react";
import store from '@src/store';
const Home= () => {
  console.log(store.getState())
  return (
    <>
    </>
  );
};

export default Home;

用redux 和 localStorage都可以全局存儲(chǔ)數(shù)據(jù)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末屹徘,一起剝皮案震驚了整個(gè)濱河市酝蜒,隨后出現(xiàn)的幾起案子赏僧,更是在濱河造成了極大的恐慌种柑,老刑警劉巖务蝠,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件击奶,死亡現(xiàn)場(chǎng)離奇詭異辈双,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)柜砾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門湃望,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人局义,你說我怎么就攤上這事喜爷。” “怎么了萄唇?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵檩帐,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我另萤,道長(zhǎng)湃密,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任四敞,我火速辦了婚禮泛源,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘忿危。我一直安慰自己达箍,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布铺厨。 她就那樣靜靜地躺著缎玫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪解滓。 梳的紋絲不亂的頭發(fā)上赃磨,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音洼裤,去河邊找鬼邻辉。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的值骇。 我是一名探鬼主播莹菱,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼雷客!你這毒婦竟也來了芒珠?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤搅裙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后裹芝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體部逮,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年嫂易,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了兄朋。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡怜械,死狀恐怖颅和,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缕允,我是刑警寧澤峡扩,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站障本,受9級(jí)特大地震影響教届,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜驾霜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一案训、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧粪糙,春花似錦强霎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至洒擦,卻和暖如春椿争,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背熟嫩。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工秦踪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓椅邓,卻偏偏與公主長(zhǎng)得像柠逞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子景馁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

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