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

ReactNative?狀態(tài)管理redux使用詳解

 更新時(shí)間:2023年03月10日 08:54:15   作者:張拭心  
這篇文章主要介紹了ReactNative?狀態(tài)管理redux使用詳解

正文

有同學(xué)反饋開發(fā) ReactNative 應(yīng)用時(shí)狀態(tài)管理不是很明白,接下來幾篇文章我們來對(duì)比下 React 及 ReactNative 狀態(tài)管理常用的幾種框架的使用和優(yōu)缺點(diǎn)。

首先來看下 redux 怎么使用。

以下是使用 React 和 Redux 創(chuàng)建 todo list 的一般過程,完整代碼見文章末尾:

安裝和配置開發(fā)環(huán)境

安裝 Node.js 和 create-react-app 腳手架,用于快速創(chuàng)建 React 應(yīng)用程序

npx create-react-app playpage_ts -template typescript

安裝 React 和 Redux 關(guān)聯(lián)庫 redux 和 react-redux

npm install @reduxjs/toolkit react-redux

定義數(shù)據(jù)結(jié)構(gòu)

這里我們假設(shè) TODO 就是一個(gè)文本

export type TODO = {
    text: string
}
//1.定義狀態(tài)數(shù)據(jù)
export type State = {
    todos: TODO[]
}
  • 定義行為 action,比如添加、刪除:
//2.定義行為
//action
export const ADD_TODO = 'ADD_TODO';
export const DELETE_TODO = 'DELETE_TODO';
//action creator
const ACTION_CREATOR_ADD_TODO = (text:string) => {
    return {type: ADD_TODO, payload: text}
};
const ACTION_CREATOR_DELETE_TODO = (text:string) => {
    return {type: DELETE_TODO, payload: text}
};
//分發(fā)數(shù)據(jù)變更操作,接收 store.dispatch
export function DISPATCH_ADD_TODO(dispatch: any) {
    return (text: string) => {
        dispatch(ACTION_CREATOR_ADD_TODO(text))
    }
}
export function DISPATCH_DELETE_TODO(dispatch: any) {
    return (text: string) => {
        dispatch(ACTION_CREATOR_DELETE_TODO(text))
    }
}

上面的代碼里,首先定義了行為類型( action type):ADD_TODO 和 DELETE_TODO,它們用于唯一標(biāo)識(shí)一個(gè)狀態(tài)改變行為。

然后創(chuàng)建了兩個(gè) action creator :ACTION_CREATOR_ADD_TODO 和 ACTION_CREATOR_DELETE_TODO,它們用于創(chuàng)建符合 reducer 約定的 action 對(duì)象,其中 type 標(biāo)識(shí)行為類型,payload 表示傳遞的數(shù)據(jù)。

最后創(chuàng)建了兩個(gè)函數(shù):DISPATCH_ADD_TODO 和 DISPATCH_DELETE_TODO,它們用于分發(fā)數(shù)據(jù)變更操作,簡(jiǎn)化后續(xù) connect 里的代碼。

然后創(chuàng)建行為處理函數(shù) todoReducer

import { State, TODO } from "./model";
import { ADD_TODO, DELETE_TODO } from "./todoActions";
const initState : State = {
    todos: [
        {
            text: "clean room"
        }
    ]
};
//3.創(chuàng)建行為處理函數(shù)
const todoReducer = (state: State = initState, action: any): State => {
    switch(action.type) {
        case ADD_TODO:
            //返回一個(gè)新的狀態(tài)樹
            return {
                todos: [...state.todos, {text: action.payload}]
            };
        case DELETE_TODO:
            console.log('todoReducer delete >>>' + action.payload)
            const todos = state.todos.filter((item: TODO, index: number)=> {
                return item.text != action.payload
            });
            return {
                todos
            }
        default:
            console.log('return default>>>' + JSON.stringify(state))
            return state;
    }
};
export default todoReducer;

todoReducer 的作用是根據(jù)行為,返回新的狀態(tài)。

參數(shù)是先前的狀態(tài) state 和要執(zhí)行的行為 action,根據(jù) action type 行為類型,返回不同的數(shù)據(jù)。

需要注意的是,reducer 中不能修改老數(shù)據(jù),只能新建一個(gè)數(shù)據(jù)。

  • 創(chuàng)建一個(gè) store,參數(shù)就是上面創(chuàng)建的行為處理函數(shù):
import { createStore } from 'redux';
import todoReducer from './reducers';
//4.創(chuàng)建 store,提供全局的狀態(tài)和行為處理
const store = createStore(
    todoReducer
);
//監(jiān)聽數(shù)據(jù)變化
store.subscribe( () => {
    console.log("store changed >>>" + JSON.stringify(store.getState()))
})
export default store;
import { createStore } from 'redux';
import rootReducer from './reducers';
const store = createStore(
  rootReducer,
  window.__REDUX_DEVTOOLS_EXTENSION__ && window.__REDUX_DEVTOOLS_EXTENSION__()
);
export default store;
  • 分發(fā)給子元素:
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
import { Provider } from 'react-redux';
import ReduxTodoApp from './ReduxTodoApp';
import store from './redux/store';
const root = ReactDOM.createRoot(
  document.getElementById('root') as HTMLElement
);
//5.分發(fā)給子元素
root.render(
  <Provider store={store}>
    <ReduxTodoApp/>
  </Provider>
);

上面的代碼中,我們使用使用 react-redux 的 Provider 包圍了 App 組件,這樣整個(gè) App 組件都可以獲取到 Store 中的狀態(tài)和行為處理函數(shù)。

ReduxTodoApp 是下一步要?jiǎng)?chuàng)建的 UI 組件

創(chuàng)建 UI 組件:

import {useState} from "react";
import { connect } from "react-redux";
import { State, TODO } from "./redux/model";
import {DISPATCH_ADD_TODO, DISPATCH_DELETE_TODO } from "./redux/todoActions";
//6.數(shù)據(jù)和 action 函數(shù)需要通過 prop 訪問
function ReduxTodoApp (prop: {todos: TODO[], addTodo: any, deleteTodo: any}) {
    const {todos, addTodo, deleteTodo} = prop;
    const [text, setText] = useState('');
    const handleInput = (e: any) => {
        setText(e.target.value)
    }
    const handleAddTodo = () => {
        addTodo(text)
        setText('')
    }
    const handleDeleteTodo = (text: string) => {
        deleteTodo(text)
    }
    return (
        <div style={{display: 'flex', flexDirection: 'column', alignItems: 'center', justifyContent: 'center'}}>
            <h1>This Is Redux TODO App.</h1>
            <ul>
                {todos.map((todo: TODO, index: any) => {
                    return (
                        <li key={index}>
                            <span>{todo.text}</span>
                            <button style={{marginLeft: '12px'}} onClick={() => handleDeleteTodo(todo.text)}>finish</button>
                        </li>
                    )
                })}
            </ul>
            <div style={{display: 'flex', flexDirection: 'row'}}>
                <input value={text} onChange={handleInput}/>
                <button onClick={handleAddTodo}>Add Todo</button>
            </div>
        </div>
    )
}
//外部的數(shù)據(jù)(即state對(duì)象)如何轉(zhuǎn)換為 UI 組件的參數(shù)
//mapStateToProps會(huì)訂閱 Store,每當(dāng)state更新的時(shí)候,就會(huì)自動(dòng)執(zhí)行,重新計(jì)算 UI 組件的參數(shù),從而觸發(fā) UI 組件的重新渲染。
const mapStateToProps = (state: State) => {
    console.log('mapStateToProps >>> ' + JSON.stringify(state))
    //返回的是一個(gè)對(duì)象,需要根據(jù)屬性名訪問
    return {
        todos: state.todos
    }   
}
//建立 UI 組件的參數(shù)到store.dispatch方法的映射
//定義了哪些用戶的操作應(yīng)該當(dāng)作 Action,傳給 Store
const mapDispatchToProps = (dispatch: any, ownProps: any) => {
    //返回一個(gè) Prop 對(duì)象
    return {
        addTodo: DISPATCH_ADD_TODO(dispatch),
        deleteTodo: DISPATCH_DELETE_TODO(dispatch)
    }
};
//5.組件接收數(shù)據(jù)和分發(fā)行為
export default connect(mapStateToProps, mapDispatchToProps) (ReduxTodoApp);

上面的代碼中,使用 connect 包裝了 UI 組件。

connect 的第一個(gè)參數(shù) mapStateToProps 用于返回當(dāng)前 UI 組件需要的數(shù)據(jù),這里我們獲取到 Store 中的 todos 列表。

第二個(gè)參數(shù) mapDispatchToProps 用于返回當(dāng)前 UI 組件需要向外分發(fā)的狀態(tài)操作行為,這里我們需要分發(fā)兩個(gè)行為:添加 todo 和刪除 todo,通過調(diào)用第二步中創(chuàng)建的 DISPATCH_ADD_TODO 和 DISPATCH_DELETE_TODO 實(shí)現(xiàn)。

正如名稱所示,mapStateToProps 和 mapDispatchToProps,最終都會(huì)向 Props 里添加成員。

這樣,我們的 UI 組件的 props 就會(huì)包含 mapStateToProps 中返回的狀態(tài)與 mapDispatchToProps 中的函數(shù),也就是這樣:

{
  todos: TODO[], 
  addTodo: any, 
  deleteTodo: any
}

注意名稱需要一致。

然后我們就可以在 UI 組件中通過 prop.todos 獲取數(shù)據(jù),通過 prop.addTodo 或者 prop.deleteTodo 通知修改數(shù)據(jù)。

總結(jié)一下,通過最原始的 redux 管理狀態(tài)分這幾步:

定義數(shù)據(jù)結(jié)構(gòu)類型,也就是前面的 State

  • 定義要進(jìn)行的數(shù)據(jù)修改行為 (action type),也就是前面的 ADD_TODO 和 DELETE_TODO
  • 然后創(chuàng)建 action creator,創(chuàng)建 reducer 里需要的 action 對(duì)象
  • 然后創(chuàng)建調(diào)用 store.dispatch 的函數(shù),簡(jiǎn)化 mapDispatchToProps 的代碼

有了行為后,然后就是處理行為,也就是 reducer

在其中根據(jù) action type,返回不同的狀態(tài)

有了 reducer 后,store 就齊全了,可以通過 createStore 創(chuàng)建一個(gè)全局唯一的 store

通過 react-redux 的 Provider 包裹整個(gè) app 組件,把 store 分發(fā)給所有組件

  • 最重要的一步:在 UI 組件里獲取數(shù)據(jù)和分發(fā)行為
  • 使用 react-redux 的 connect 包裹 UI 組件
  • connect 的第一個(gè)參數(shù)返回一個(gè)對(duì)象,在其中獲取 UI 組件里需要的數(shù)據(jù)
  • 第二個(gè)參數(shù)返回一個(gè)對(duì)象,其中包括要向外分發(fā)的行為
  • 在 UI 組件里通過 props.xxx 的方式獲取數(shù)據(jù)和分發(fā)行為

步驟有些繁瑣,但重要的是,行為和行為處理都拆分開,及時(shí)業(yè)務(wù)變得復(fù)雜,后續(xù)拓展也比較輕松。

如果要分析某個(gè)狀態(tài)修改操作,在 reducer 里增加日志即可定位到,這就是 redux 宣稱的優(yōu)勢(shì):“可追溯”。

完整代碼:github.com/shixinzhang…

以上就是ReactNative 狀態(tài)管理redux使用詳解的詳細(xì)內(nèi)容,更多關(guān)于ReactNative狀態(tài)管理redux 的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React18使用Echarts和MUI實(shí)現(xiàn)一個(gè)交互性的溫度計(jì)

    React18使用Echarts和MUI實(shí)現(xiàn)一個(gè)交互性的溫度計(jì)

    這篇文章我們將結(jié)合使用React 18、Echarts和MUI(Material-UI)庫,展示如何實(shí)現(xiàn)一個(gè)交互性的溫度計(jì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • React事件處理超詳細(xì)介紹

    React事件處理超詳細(xì)介紹

    這篇文章主要介紹了React事件處理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-09-09
  • 從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟(附源碼)

    從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟(附源碼)

    本文主要介紹了從零搭建Webpack5-react腳手架的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • React?Hook實(shí)現(xiàn)對(duì)話框組件

    React?Hook實(shí)現(xiàn)對(duì)話框組件

    這篇文章主要為大家詳細(xì)介紹了React?Hook實(shí)現(xiàn)對(duì)話框組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • React中的Refs屬性你來了解嗎

    React中的Refs屬性你來了解嗎

    這篇文章主要為大家詳細(xì)介紹了的React?Refs屬性,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • React實(shí)現(xiàn)文件分片上傳和下載的方法詳解

    React實(shí)現(xiàn)文件分片上傳和下載的方法詳解

    在當(dāng)今的前端開發(fā)中,處理文件流操作已經(jīng)成為一個(gè)常見的需求,無論是上傳、下載、讀取、展示還是其他的文件處理操作,都需要高效且可靠地處理二進(jìn)制數(shù)據(jù),本文將深入探討如何使用 React 實(shí)現(xiàn)文件分片上傳和下載,并介紹相關(guān)的基本概念和技術(shù),需要的朋友可以參考下
    2023-08-08
  • 減少react組件不必要的重新渲染實(shí)現(xiàn)方法

    減少react組件不必要的重新渲染實(shí)現(xiàn)方法

    這篇文章主要為大家介紹了減少react組件不必要的重新渲染實(shí)現(xiàn)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • React中實(shí)現(xiàn)編輯框自動(dòng)獲取焦點(diǎn)與失焦更新功能

    React中實(shí)現(xiàn)編輯框自動(dòng)獲取焦點(diǎn)與失焦更新功能

    在React應(yīng)用中,編輯框的焦點(diǎn)控制和數(shù)據(jù)回填是一個(gè)常見需求,本文將介紹如何使用useRef和useEffect鉤子,在組件中實(shí)現(xiàn)輸入框自動(dòng)獲取焦點(diǎn)及失焦后更新數(shù)據(jù)的功能,文中通過代碼示例給大家講解的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • react 實(shí)現(xiàn)圖片正在加載中 加載完成 加載失敗三個(gè)階段的原理解析

    react 實(shí)現(xiàn)圖片正在加載中 加載完成 加載失敗三個(gè)階段的原理解析

    這篇文章主要介紹了react 實(shí)現(xiàn)圖片正在加載中 加載完成 加載失敗三個(gè)階段的,通過使用loading的圖片來占位,具體原理解析及實(shí)現(xiàn)代碼跟隨小編一起通過本文學(xué)習(xí)吧
    2021-05-05
  • React?Server?Component混合式渲染問題詳解

    React?Server?Component混合式渲染問題詳解

    React?官方對(duì)?Server?Comopnent?是這樣介紹的:?zero-bundle-size?React?Server?Components,這篇文章主要介紹了React?Server?Component:?混合式渲染,需要的朋友可以參考下
    2022-12-12

最新評(píng)論