redux action的使用

继续上次的教程,还是先看图:

这次我们完成对reducer的修改,然后更新dom,文件目录结构如下

首先监听数据的改变,写好input组件的onchange方法

					<Input 
						value={this.state.inputValue} 
						placeholder='todo info' 
						style={{width: '300px', marginRight: '10px'}}
						onChange={this.handleInputChange}
					/>

然后再onchange方法中添加action 把这个动作派发给reducer, action是一个对象。首先需要定义action的type,这个就相当于名字,然后就是value值,把值传给reducer。

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

reduce接收到这个action进行处理,通过type判断改变谁的值。然后深拷贝jsson.stringify。然后将新的newstate返回。这里注意reduce不可以直接改变state的值。所以我们要先拷贝一份state,再将新的state return出去

	if (action.type === 'change_input_value') {
		const newState = JSON.parse(JSON.stringify(state));
		newState.inputValue = action.value;
		return newState;
	}

然后在todolist中,订阅store的改变。当reducer改变了 就会收到通知

	constructor(props) {
		super(props);
		store.subscribe(this.handleStoreChange);
	}

最后一步,收到store改变的通知,我们可以重新获取store中的state,然后出发setstate方法,重新触发render函数,刷新页面

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redux 是一个用于 JavaScript 应用程序的可预测状态容器,它可以帮助开发者更好地管理应用程序的状态。Redux 的核心思想是将应用程序的状态存储在一个单一的对象中,并使用纯函数对其进行修改。以下是 Redux 的基本用法: 1. 安装 Redux 可以通过 npm 或 yarn 进行安装,如下所示: ``` npm install redux ``` 或 ``` yarn add redux ``` 2. 创建 store 在 Redux 中,store 是一个保存应用程序状态的对象。可以通过 createStore 函数创建 store,如下所示: ``` import { createStore } from 'redux'; function reducer(state, action) { // 处理 action 并返回新的 state } const store = createStore(reducer); ``` 在上面的代码中,reducer 是一个纯函数,它接收当前的 state 和 action,并返回新的 state。store 会在应用程序中保存这个 state。 3. 定义 actionRedux 中,action 是一个描述 state 变化的普通对象。例如,以下是一个增加计数器值的 action: ``` const incrementAction = { type: 'INCREMENT', payload: 1, }; ``` 在这个例子中,action 的 type 是 INCREMENT,payload 是增加的数量。 4. 分发 action 使用 store.dispatch 函数可以将 action 发送到 reducer 中处理,并返回新的 state。 ``` store.dispatch(incrementAction); ``` 5. 订阅 store 使用 store.subscribe 函数可以监听 store 中 state 的变化,并在变化时执行相应的操作。 ``` store.subscribe(() => { console.log(store.getState()); }); ``` 在上面的代码中,每当 state 发生变化时,都会将当前的 state 打印到控制台中。 以上就是 Redux 的基本使用方法。需要注意的是,Redux 可以与 React 等前端框架结合使用,以实现更好的状态管理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值