溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么使用react+redux實現(xiàn)彈出框

發(fā)布時間:2022-08-25 16:55:45 來源:億速云 閱讀:197 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“怎么使用react+redux實現(xiàn)彈出框”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么使用react+redux實現(xiàn)彈出框”吧!

redux 實現(xiàn)彈出框案例

1、實現(xiàn)效果,點擊顯示按鈕出現(xiàn)彈出框,點擊關(guān)閉按鈕隱藏彈出框

新建彈出框組件 src/components/Modal.js, 在index.js中引入app組件,在app中去顯示計數(shù)器和彈出框組件

function Modal ({ showState, show, hide }) {
    const styles = {
        width: 200,
        height: 200,
        position: 'absolute',
        top: '50%',
        left: '50%',
        marginTop: -100,
        marginLeft: -100,
        backgroundColor: 'skyblue',
    }
    return <div>
        <button>顯示</button>
        <button>隱藏</button>
        <div  style={styles}></div>
    </div>
}

2、彈出框組件顯示隱藏是一個狀態(tài),所以我們存儲到store中,命名為show,因為需要出發(fā)action來修改store中的狀態(tài)所系我們需要創(chuàng)建modal.actions.js文件,來存儲控制顯示隱藏的action,我們還是把顯示與隱藏aciton的type定義為常量方便導(dǎo)入使用

// src/store/const/modal.const.js
export const SHOWMODAL = 'showModal'
export const HIDEMODAL = 'hideModal'

// src/store/actions/modal.actions.js
import { SHOWMODAL, HIDEMODAL} from './../const/modal.const'

export const show = () => ({type: SHOWMODAL})
export const hide = () => ({type: HIDEMODAL})

// src/store/reducers/counter.reducers.js
import { INCREMENT, DECREMENT } from './../const/counter.const'
import { SHOWMODAL, HIDEMODAL } from './../const/modal.const'

const initialState = {
    count: 0,
    // 增加控制modal 顯示隱藏顯示的狀態(tài),默認(rèn)為隱藏狀態(tài)
    show: false
}
// eslint-disable-next-line import/no-anonymous-default-export
export default (state = initialState, action) => {
    switch (action.type) {
        case INCREMENT:
            return {
                count: state.count + action.payload
            }
        case DECREMENT:
            return {
                count: state.count - action.payload
            }
        case SHOWMODAL:
            return {
                show: true
            }
        case HIDEMODAL:
            return {
                show: false
            }

        default:
            return state
    }
}

3、彈框的顯示隱藏狀態(tài)用display屬性控制所以我們需要把狀態(tài)映射到props屬性中,因為show狀態(tài)與show顯示方法重名了,所以給show狀態(tài)起一個別名,利用 bindActionCreators 方法把 執(zhí)行 dispatch 提交actions的方法映射到props中

import React from 'react'
import { connect } from 'react-redux'
import * as modalActions from './../store/actions/modal.actions'
import { bindActionCreators } from 'redux'

function Modal ({ showState, show, hide }) {
    const styles = {
        width: 200,
        height: 200,
        position: 'absolute',
        top: '50%',
        left: '50%',
        marginTop: -100,
        marginLeft: -100,
        backgroundColor: 'skyblue',
        // 增加控制顯示隱藏的css樣式
        display: showState ? 'block' : 'none'
    }
    return <div>
        <button onClick={show}>顯示</button>
        <button onClick={hide}>隱藏</button>
        <div  style={styles}></div>
    </div>
}
// 映射顯示英藏狀態(tài)到props中
const mapStateToProps = state => {
    return {
        showState: state.show
    }
}
// 把提交actions方法映射到組件props中
const mapDispacthToProps = dispatch => bindActionCreators(modalActions, dispatch)
export default connect(mapStateToProps,mapDispacthToProps)(Modal)

通過上面我們發(fā)現(xiàn)在點擊顯示與隱藏之后計數(shù)器組件中的數(shù)字不見了,因為我們在執(zhí)行顯示與隱藏的方法中并沒有返回 計數(shù)器的狀態(tài)所以這個狀態(tài)丟失掉了,我們需要在更改狀態(tài)的時候去補(bǔ)上原有的狀態(tài)

4、補(bǔ)上原有狀態(tài)

export default (state = initialState, action) => {
    switch (action.type) {
        case INCREMENT:
            return {
                ...state,
                count: state.count + action.payload
            }
        case DECREMENT:
            return {
                ...state,
                count: state.count - action.payload
            }
        case SHOWMODAL:
            return {
                ...state,
                show: true
            }
        case HIDEMODAL:
            return {
                ...state,
                show: false
            }

        default:
            return state
    }
}

這個時候我們的計數(shù)器與彈出框組件都已經(jīng)正常了,但是我們發(fā)現(xiàn)reducer函數(shù)隨著actions動作越來越多變的越來越臃腫,在狀態(tài)越來越多以后將會變得無法維護(hù)

拆分reducer 函數(shù)

在計數(shù)器與彈出框案例中,在reducer函數(shù)中,我們既匹配到了計數(shù)器案例中的actions,又匹配到了彈出框案例中的actions 這樣reducer中的代碼將會越來越龐大,越來越臃腫,所以我們接下來拆分reducer,拆分reducer我們需要用到 combineReducers 方法,這個方法要求我們傳遞一個對象 這個對象是狀態(tài)對象,返回值是合并后的reducer

1、創(chuàng)建 src/store/reducers/modal.reducers.js 文件,把彈出框的reducer抽離出來

import { SHOWMODAL, HIDEMODAL } from './../const/modal.const'

const initialState = {
    show: false
}

// eslint-disable-next-line import/no-anonymous-default-export
export default (state = initialState, action) => {
    switch (action.type) {

        case SHOWMODAL:
            return {
                ...state,
                show: true
            }
        case HIDEMODAL:
            return {
                ...state,
                show: false
            }

        default:
            return state
    }
}

2、創(chuàng)建src/store/reducers/root.reducers.js 文件,用于合并計數(shù)器與彈出框的reducer

import { combineReducers } from 'redux'
import CounterReducers from './counter.reducers'
import ModalReducers from './modal.reducers'

// 要求我們傳遞一個對象 這個對象是狀態(tài)對象
// 這樣寫了之后 狀態(tài)的結(jié)構(gòu)將是這樣 counter: { count: 0 } modaler: { show: false }
export default combineReducers({
    counter: CounterReducers,
    modaler: ModalReducers
})

3、因為使用 combineReducers 合并reducer的時候改變了state的結(jié)構(gòu)所以我們需要在組件中去更改獲取state的方式

// src/components/Count.js
const mapStateProps = ({ counter }) => ({
    count: counter.count,
    a: '1'
})
// src/components/Modal.js
const mapStateToProps = ({ modaler }) => {
    return {
        showState: modaler.show
    }
}

到此,相信大家對“怎么使用react+redux實現(xiàn)彈出框”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI