使用action与reducer

本文详细介绍了如何在图书管理系统中使用Redux模式进行状态管理。具体步骤包括:通过action将借书人的输入传递给store,store调用reducer查询并更新状态,最后将更新后的状态返回给组件显示。文章还提供了代码示例,如handleInputChange方法用于监听输入框变化,store.dispatch用于发送action,reducer用于处理state变化,store.subscribe用于监听store状态变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里主要研究通过action(借书人说的话)传递给store(管理员),store再从reducer(记录本)查询数据,reducer将查询到的数据返回给store,最后store再返回给组件(借书用户)。最终要实现当reducers数据发生变化的时候,组件的数据也跟着变化

1.当组件的input框输入内容发生改变时,自动调用handleInputChange,通过store.dispatch()将数据发送给store(管理员)

handleInputChang (e){
        const action = {
            type: 'chang_input_value',
            value: e.target.value
        }
        store.dispatch(action);
    }

2.store会自动将previousState与接收到的action传递给reducers(记录本)

3.reducers接收store传递过来的数据进行判断,如果为真将其新数据返回给store

//reducer可以接收state的数据,但是不可以修改
export default (state = defaultState , action) => {
    if(action.type === 'chang_input_value') {
        const newState = JSON.parse(JSON.stringify(state)) //深拷贝
        newState.inputValue = action.value;
        return newState;
    }
    return state;
}

4.组件订阅store的改变,只要store改变,就触发该方法

//订阅store的改变,只要store改变,就触发该方法
store.subscribe(this.handleStoreChange)

将其写到custructor中

5.将最新的store数据获取到

handleStoreChange () {
        this.setState(store.getState())
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值