欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用Redux Toolkit簡(jiǎn)化Redux

 更新時(shí)間:2022年12月22日 10:57:59   作者:咸蛋超人l  
redux-toolkit是目前redux官方推薦的編寫redux邏輯的方法,針對(duì)redux的創(chuàng)建store繁瑣、樣板代碼太多、依賴外部庫(kù)等問(wèn)題進(jìn)行了優(yōu)化,官方總結(jié)了四個(gè)特點(diǎn)是簡(jiǎn)易的/有想法的/強(qiáng)勁的/高效的,總結(jié)來(lái)看,就是更加的方便簡(jiǎn)單了

一、安裝Redux Toolkit和React-Redux

注: “@reduxjs/toolkit”: “^1.8.6”, “react-redux”: “^8.0.4”

npm install @reduxjs/toolkit react-redux

二、創(chuàng)建Redux Store

從Redux Toolkit里引入configureStore,我們將從創(chuàng)建和導(dǎo)出一個(gè)空的Redux store開(kāi)始。

store/index.js
// 使用rtk來(lái)創(chuàng)建store
import { configureStore } from '@reduxjs/toolkit'
import useReducer from './userSlice'
/* 
使用rtk的時(shí)候,reducer依然可以使用之前的創(chuàng)建不變
但是不再需要去合并reducer combineReducers
rtk提供了configureStore方法,直接接收一個(gè)對(duì)象作為參數(shù)
可以將reducer的相關(guān)配置直接通過(guò)這個(gè)對(duì)象進(jìn)行傳遞,不再需單獨(dú)合并reducer
reducer屬性可以直接單獨(dú)傳遞一個(gè)ruducer,也可以傳遞一個(gè)對(duì)象
*/
const store = configureStore({
  reducer: {
    user: useReducer
  }
})
export default store

三、在React中使用Redux Store

我們就可以在src/index.js文件中用React-Redux提供的包裹我們的應(yīng)用,這樣我們就可以在React組件中使用React store了

具體操作就是先引入我們剛剛創(chuàng)建的Redux store,然后用包裹你的,再將store作為一個(gè)prop傳入。

src/index.js

import React from 'react'
import ReactDOM from 'react-dom/client'
import App from './App'
import { Provider } from 'react-redux'
import store from './store'
const root = ReactDOM.createRoot(document.getElementById('root'))
root.render(
  <Provider store={store}>
    <App />
  </Provider>
)

四、創(chuàng)建一個(gè)Redux State Slice

slice需要一個(gè)name作為唯一標(biāo)識(shí),需要有初始化state值,還需要至少一個(gè)reducer方法來(lái)定義state如何變化。一旦slice創(chuàng)建完成我們就可以導(dǎo)出生成的Redux action creators和整個(gè)slice的reducer方法。

Redux需要我們通過(guò)制作數(shù)據(jù)副本和更新副本來(lái)不可變地更新state。然而Redux Toolkit的createSlice 和 createReducer API內(nèi)部使用了Immer,這允許我們可以直接寫更新邏輯,不必制作副本,它將自動(dòng)成為正確的不可變更新。

userSlice.js文件

// 切片對(duì)象
import { createSlice } from '@reduxjs/toolkit'
/* 
reducer切片
createSlice函數(shù)的作用:生成分片的reducer
內(nèi)部調(diào)用的市createAction和createReducer 
creatSlice可以幫助我們用更少的代碼去生成配套的reducer和action,而且有很好的維護(hù)性
*/
const userSlice = createSlice({
  name: 'zhangsan', // 標(biāo)識(shí)符,生成actions的時(shí)候要使用,
  // state初始值
  initialState: {
    name: '張三',
    age: 18,
    gender: '男'
  } ,
  // reducer的具體方法,
  reducers: {
    // 指定state的各種操作,直接就可以在對(duì)象中添加方法
    setName(state, action) {
      /* 
      可以通過(guò)不同的方法修來(lái)指定對(duì)state的不同的操作
      state,action 
      可以直接修改state => state 是一個(gè)代理對(duì)象  之前的復(fù)制一份,返回一個(gè)新的對(duì)象
      */
      state.name = action.payload
    },
    setAge(state, action) {
      state.age = action.payload
    }
  }
})
/* 
切片對(duì)象會(huì)自動(dòng)地幫助我們生成action
切片對(duì)象會(huì)根據(jù)我們地reducers方法來(lái)自動(dòng)地創(chuàng)建action對(duì)象,這些action對(duì)象會(huì)保存到切片對(duì)象的actions中
{type:name/函數(shù)名,payload:函數(shù)的參數(shù)}
*/
// 實(shí)際開(kāi)發(fā)中,setName,setAge對(duì)外暴露,
export const { setName, setAge } = userSlice.actions
export default userSlice.reducer

五、在React組件中使用Redux State和Action

現(xiàn)在我們可以使用React-Redux鉤子在React組件中操作Redux store。我們可以使用useSelector從store中讀取數(shù)據(jù),也可以使用useDispatch來(lái)dispatch actions。

src/App.js

import React from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { setName, setAge } from './store/userSlice'
export default function App() {
  const user = useSelector(state => state.user)
  const dispatch = useDispatch()
  const setNameHandler = () => {
    dispatch(setName('李四'))
  }
  const setAgeHandler = () => {
    dispatch(setAge(20))
  }
  return (
    <div>
      <h1>{user.name}</h1>
      <h1>{user.age}</h1>
      <h1>{user.gender}</h1>
      <button onClick={setNameHandler}>修改name</button>
      <button onClick={setAgeHandler}>修改年齡</button>
    </div>
  )
}

以上是關(guān)于如何在React中設(shè)置和使用 Redux Toolkit的簡(jiǎn)要概述?;仡櫦?xì)節(jié):

1、使用configureStore創(chuàng)建一個(gè)Redux Store

  • configureStore接收reducer方法作為命名參數(shù),或者說(shuō)作為reducer對(duì)象的屬性
  • configureStore會(huì)使用默認(rèn)設(shè)置自動(dòng)設(shè)置好store

2、在React組件中使用 Redux store

  • 用React-Redux提供的 包裹你的
  • 使用 傳入Redux store

3、使用createSlice創(chuàng)建Redux “slice” reducer

  • createSlice需要有name屬性作為唯一標(biāo)識(shí),還需要初始化state和已命名的reducer方法
  • Reducer方法通過(guò)使用Immer可以直接“改變”state,而不必手動(dòng)做副本
  • 導(dǎo)出生成的slice reducer 和 action creators

4、在React組件中使用React-Redux的useSelector/useDispatch鉤子

  • 使用useSelector鉤子從store中讀數(shù)據(jù)
  • 使用useDispatch鉤子獲取到dispatch方法,并且根據(jù)需要dispatch actions

到此這篇關(guān)于如何使用Redux Toolkit簡(jiǎn)化Redux的文章就介紹到這了,更多相關(guān)Redux Toolkit內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • antd中form表單的wrapperCol和labelCol問(wèn)題詳解

    antd中form表單的wrapperCol和labelCol問(wèn)題詳解

    最近學(xué)習(xí)中遇到了些問(wèn)題,所以給大家總結(jié),下面這篇文章主要給大家介紹了關(guān)于antd中form表單的wrapperCol和labelCol問(wèn)題的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • React觸發(fā)render的實(shí)現(xiàn)方法

    React觸發(fā)render的實(shí)現(xiàn)方法

    這篇文章主要介紹了React觸發(fā)render的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • React模仿網(wǎng)易云音樂(lè)實(shí)現(xiàn)一個(gè)音樂(lè)項(xiàng)目詳解流程

    React模仿網(wǎng)易云音樂(lè)實(shí)現(xiàn)一個(gè)音樂(lè)項(xiàng)目詳解流程

    這篇文章主要介紹了React模仿網(wǎng)易云音樂(lè)實(shí)現(xiàn)一個(gè)音樂(lè)項(xiàng)目的詳細(xì)流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板

    react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板

    這篇文章主要介紹了react同構(gòu)實(shí)踐之實(shí)現(xiàn)自己的同構(gòu)模板,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • React全局狀態(tài)管理的三種底層機(jī)制探究

    React全局狀態(tài)管理的三種底層機(jī)制探究

    近兩年前端技術(shù)的發(fā)展如火如荼,大量的前端項(xiàng)目都在使用或轉(zhuǎn)向 Vue 和 React 的陣營(yíng),由前端渲染頁(yè)面的單頁(yè)應(yīng)用占比也越來(lái)越高,這篇文章主要給大家介紹了關(guān)于React全局狀態(tài)管理的三種底層機(jī)制,需要的朋友可以參考下
    2021-09-09
  • react+antd 遞歸實(shí)現(xiàn)樹(shù)狀目錄操作

    react+antd 遞歸實(shí)現(xiàn)樹(shù)狀目錄操作

    這篇文章主要介紹了react+antd 遞歸實(shí)現(xiàn)樹(shù)狀目錄操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • ReactNative之FlatList的具體使用方法

    ReactNative之FlatList的具體使用方法

    本篇文章主要介紹了ReactNative之FlatList的具體使用方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • react組件中過(guò)渡動(dòng)畫的問(wèn)題解決

    react組件中過(guò)渡動(dòng)畫的問(wèn)題解決

    這篇文章主要為大家介紹了react組件中過(guò)渡動(dòng)畫的問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • React之使用useState異步刷新的問(wèn)題

    React之使用useState異步刷新的問(wèn)題

    這篇文章主要介紹了React之使用useState異步刷新的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 淺談python的函數(shù)知識(shí)

    淺談python的函數(shù)知識(shí)

    這篇文章主要為大家介紹了python的函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-11-11

最新評(píng)論