redux将所有数据存储到树中,且树是唯一的。
Redux基本概念
store
:存储树结构。state
:维护的数据,一般维护成树的结构。reducer
:对state
进行更新的函数,每个state
绑定一个reducer
。传入两个参数:当前state
和action
,返回新state
。action
:一个普通对象,存储reducer
的传入参数,一般描述对state
的更新类型。dispatch
:传入一个参数action
,对整棵state
树操作一遍。React-Redux基本概念
Provider
组件:用来包裹整个项目,其store
属性用来存储redux
的store
对象。connect(mapStateToProps, mapDispatchToProps)
函数:用来将store
与组件关联起来。mapStateToProps
:每次store
中的状态更新后调用一次,用来更新组件中的值。mapDispatchToProps
:组件创建时调用一次,用来将store
的dispatch
函数传入组件。
安装
npm i redux react-redux @reduxjs/toolkit
使用
导入包
在定义store的jsx中导入,当然如果是写在一个文件中就没关系
import { configureStore } from "@reduxjs/toolkit";
在main.jsx/index.jsx中导入Provider
import { Provider } from 'react-redux';
在每一个需要使用到redux全局变量的组件内部导入connect
import { connect } from 'react-redux';
定义actions
可以单独写一个文件,中放一个对象的全局变量来存actions
定义reducer
reducer是一个函数,需要传入两个参数,一个是state,另外一个是action
action是一个对象,state是当前存的数据,需要赋一个初值
例如:
const reducer = (state="0", action) => {
switch(action.type) {
}
};
state同时可以维护一个对象,此时reducer可以这样写
const reducer = (state={
currentOperand: "",
lastOperand: "",
operation: "",
}, action) => {
switch(action.type) {
default:
return state;
}
};
定义store
const store = configureStore({
reducer: reducer
});
store 和两个reducer的名称可以任意,自己知道就行。
这里reducer和reducer重名,可以只写一个reducer来表示reducer: reducer
例如:
const store = configureStore({
reducer
});
使用store
在main.jsx/index.jsx中将有使用redux的组件用<Provider></Provider>
括起来,同时需要给Provider传一个参数store,就是我们定义的store
例如:
<Provider store={store}>
<BrowserRouter>
<App />
</BrowserRouter>
</Provider>
mapDispatchToProps
将dispatch函数绑定到组件上
mapDispatchToProps函数定义
例如:
const mapDispatchToProps = {
add_digit: digit => {
return {
type: ACTIONS.ADD_DIGIT,
digit: digit,
}
}
}
使用connect组件绑定
例如:
export default connect(null, mapDispatchToProps)(DigitButton);
之后就可以通过 this.props.add_digit
来使用add_digit函数了
mapStateToProps
将state数据绑定到组件上
mapStateToProps函数定义
例如:
const mapStateToProps = (state, props) => {
return {
currentOperand: state.currentOperand,
lastOperand: state.lastOperand,
operation: state.operation,
}
}
使用connect组件绑定
例如
export default connect(mapStateToProps)(Calculator);
之后就可以通过 this.props. ...
来访问state中的数据了