react react-redux学习记录
- 1.原理
- 2.怎么用呢
- 2.1 容器组件
- 2.2UI组件
- 2.3 App.jsx
- 3.简化
- 3.1简写mapDispatch
- 3.2 Provider组件的使用
- 3.3整合UI组件和容器组件
1.原理
UI组件:不能使用任何redux的api,只负责页面的呈现、交互等。
容器组件:负责和redux通信,将结果交给UI组件。看得出来容器组件很重要的,它连接着ui组件和redux
2.怎么用呢
文件目录结构:
2.1 容器组件
import CountUI from '../../components/Count';
//引入action
import {
createIncrementAction,
createSubtractionAction,
createIncrementAsyncAction
} from '../../redux/count_action'
//connect的第一个第一个参数主要可传两个参数,相当于将store中的状态和操作状态传递给UI组件
import { connect } from 'react-redux';
/*
1.mapStateToProps函数返回的是一个对象;
2.返回的对象中的key就作为传递给UI组件props的key,value就作为传递给UI组件props的value
3.mapStateToProps用于传递状态
*/
function mapStateToProps(state){
return {count:state}
}
/*
1.mapDispatchToProps函数返回的是一个对象;
2.返回的对象中的key就作为传递给UI组件props的key,value就作为传递给UI组件props的value
3.mapDispatchToProps用于传递操作状态的方法
*/
function mapDispatchToProps(dispatch){
return {
jia:number => dispatch(createIncrementAction(number)),
jian:number => dispatch(createSubtractionAction(number)),
jiaAsync:(number,time) => dispatch(createIncrementAsyncAction(number,time)),
}
}
//使用connect()()创建并暴露一个Count的容器组件
export default connect(mapStateToProps,mapDispatchToProps)(CountUI)
2.2UI组件
import React, { Component } from "react";
import store from "../../redux/store";
export default class Count extends Component {
state = { carName: "奔驰c63" };
componentDidMount() {
store.subscribe(() => {
this.setState({});
});
}
//加法
increment = () => {
const { value } = this.selectNumber;
this.props.jia(value*1)
};
//减法
decrement = () => {
const { value } = this.selectNumber;
this.props.jian(value*1,500)
};
//奇数再加
incrementIfOdd = () => {
const { value } = this.selectNumber;
if (this.props.count % 2 !== 0) {
this.props.jia(value*1)
}
};
//异步加
incrementAsync = () => {
const { value } = this.selectNumber;
this.props.jiaAsync(value*1,500)
};
render() {
console.log('UI组件接收到的props是',this.props);
return (
<div>
<h1>当前求和为:{this.props.count}</h1>
<select ref={(c) => (this.selectNumber = c)}>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<button onClick={this.increment}>+</button>
<button onClick={this.decrement}>-</button>
<button onClick={this.incrementIfOdd}>当前求和为奇数再加</button>
<button onClick={this.incrementAsync}>异步加</button>
</div>
);
}
}
2.3 App.jsx
import React, { Component } from 'react'
import Count from './containers/Count'
import store from './redux/store'
export default class App extends Component {
render() {
return (
<div>
<Count store={store}/>
</div>
)
}
}
3.简化
3.1简写mapDispatch
export default connect(mapStateToProps, {
//和之前的箭头函数都是返回的一个action对象,react-redux优化了自动分发dispatch
jia: createIncrementAction,
jian: createSubtractionAction,
jiaAsync: createIncrementAsyncAction,
})(CountUI);
3.2 Provider组件的使用
不使用react-redux的话,需要在在index.js写上对redux的监听
//这是react18.0之前的版本写法
store.subscrible(() =>{
ReactDOM.render(<App/>,document.getElementById("root"))
})
使用react-redux的话,不需要监听的了;而且在App.jsx中:
如果有很多的容器组件,那就需要写很多重复的store={store},优化是当前页面:
然后再index.js中使用Provider组件
3.3整合UI组件和容器组件
直接将UI组件和容器组件整合成一个
import React, { Component } from "react";
//引入action
import {
createIncrementAction,
createSubtractionAction,
createIncrementAsyncAction,
} from "../../redux/count_action";
//connect的第一个第一个参数主要可传两个参数,相当于将store中的状态和操作状态传递给UI组件
import { connect } from "react-redux";
export class Count extends Component {
state = { carName: "奔驰c63" };
//加法
increment = () => {
const { value } = this.selectNumber;
this.props.jia(value*1)
};
//减法
decrement = () => {
const { value } = this.selectNumber;
this.props.jian(value*1,500)
};
//奇数再加
incrementIfOdd = () => {
const { value } = this.selectNumber;
if (this.props.count % 2 !== 0) {
this.props.jia(value*1)
}
};
//异步加
incrementAsync = () => {
const { value } = this.selectNumber;
this.props.jiaAsync(value*1,500)
};
render() {
console.log('UI组件接收到的props是',this.props);
return (
<div>
<h1>当前求和为:{this.props.count}</h1>
<select ref={(c) => (this.selectNumber = c)}>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<button onClick={this.increment}>+</button>
<button onClick={this.decrement}>-</button>
<button onClick={this.incrementIfOdd}>当前求和为奇数再加</button>
<button onClick={this.incrementAsync}>异步加</button>
</div>
);
}
}
/*
1.mapStateToProps函数返回的是一个对象;
2.返回的对象中的key就作为传递给UI组件props的key,value就作为传递给UI组件props的value
3.mapStateToProps用于传递状态
*/
function mapStateToProps(state) {
return { count: state };
}
/*
1.mapDispatchToProps函数返回的是一个对象;
2.返回的对象中的key就作为传递给UI组件props的key,value就作为传递给UI组件props的value
3.mapDispatchToProps用于传递操作状态的方法
*/
// function mapDispatchToProps(dispatch){
// return {
// jia:createIncrementAction,
// jian:createSubtractionAction,
// jiaAsync:createIncrementAsyncAction,
// }
// }
//使用connect()()创建并暴露一个Count的容器组件
export default connect(mapStateToProps, {
//和之前的箭头函数都是返回的一个action对象,react-redux优化了自动分发dispatch
jia: createIncrementAction,
jian: createSubtractionAction,
jiaAsync: createIncrementAsyncAction,
})(Count);