Réagir 之 réagir-redux

  1. La différence avec redux :

  1. C'est relativement simple, sans écrire d'abonnement, c'est en fait une version simplifiée de Redux.

  1. L'accent est mis sur les fournisseurs (Provider) et les connecteurs (connect), et deux mappages (stateToProps, dispatchToProps)

  1. Installez react-redux, redux

npm install --save react-redux
npm install --save redux
  1. Utilisez react-redux pour obtenir une accumulation

1) Créer un entrepôt de magasin

src>store>index.js :

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

const store = createStore(reducer)
export default store

src>store>reducer.js :

const defaultState = {
    num: 0
}
//导出(一开始的时候,state作为形参,一开始没有值,所以让他等于defaultState)
export default (state = defaultState, action) => {
    return state
}

2) Supprimez tous les fichiers sous src et créez index.js et Add.js sous src

Ajouter.js :

import React, { Component } from 'react'
import { connect } from 'react-redux'
class Add extends Component {
    render() {
        return (
            <div>
                <div>num: {this.props.num}</div>
                <button onClick={this.props.addnum}>增加</button>
            </div>
        )
    }
}
// stateToProps是一种映射关系,把原来的state映射成组件中的props属性
const stateToProps = (state) => {
    return {
        num: state.num
    }
}
// dispatchToProps也是一种映射,用于传递并修改数据,这里要返回一个对象并包含一个事件
const dispatchToProps = (dispatch) => {
    return {
        addnum() {
            const action = {
                type: 'add_fn',
                value: 1
            }

            dispatch(action)
        }
    }
}

// 导出连接器
export default connect(stateToProps, dispatchToProps)(Add)

index.js :

import React from 'react'
import { createRoot } from 'react-dom/client'
import { Provider } from 'react-redux'
import store from './store'

import Add from './Add'
const root = createRoot(document.getElementById('root'))
root.render(
// Provider (提供器)组件
    <Provider store = {store}>
        <Add />
    </Provider>
)

* Ensuite, tous les composants du fournisseur Provider peuvent obtenir les données dans le magasin.

3) Ensuite, dans reducer.js, l'accumulation est réalisée en déclenchant l'action.

const defaultState = {
    num: 0
}
//导出(一开始的时候,state作为形参,一开始没有值,所以让他等于defaultState)
export default (state = defaultState, action) => {
    //对原本的state做一次深拷贝。 
    //reducer只能接收state,不能直接对它进行改变
    var newState = JSON.parse(JSON.stringify(state))
    //通过判断action的type,确定是否需要修改
    switch (action.type) {
        case 'add_fn':
            newState.num += action.value;
            break;
        default:
            break;
    }
    return newState
}

Je suppose que tu aimes

Origine blog.csdn.net/CSSAJBQ_/article/details/128919554
conseillé
Classement