1 回答
TA贡献1796条经验 获得超7个赞
你需要纠正的事情:
在这里,您返回一个数组,但您的状态是一个对象。
case 'SET_FACILITY_NAME':
return [
...state,
action.facilityName
];
如果你看一下这行代码:
setCMSId(this.state.cmsCertificationNumber)
您只是在调用返回对象的函数。您应该调度该操作。
您有一个未使用的功能
function mapStateToProps(state) {
const { CMSReducer } = state
return { CMSForm: CMSReducer }
}
您没有使用此处映射到道具的状态:
export default connect(state => ({ cmsNum: getCMSNum(state) }))(CMSForm);
更新
您可以通过这种方式使用调度:
import React from 'react'
import { connect } from 'react-redux';
import { setCMSId } from '../redux/methods'
import { getCMSNum } from "../redux/selectors";
class CMSForm extends React.Component {
constructor(props) {
super(props);
this.state = {
cmsCertificationNumber: '',
facility_name: ''
};
}
handleCmsNumber = () => {
// to dispatch the `setCMSId` action.
this.props.setCMSId(this.state.cmsCertificationNumber);
} // end of HandleCMSNumebr
handleChange = (event) => {
this.setState({ cmsCertificationNumber: event.target.value });
}
render() {
console.log(this.props.cmsNum);
return (
<div>
<input type="text" value={this.state.cmsCertificationNumber} onChange={this.handleChange} />
<button className="update-cmsNum" onClick={this.handleCmsNumber}>
Find
</button>
</div>
)
}
} // end of component
const mapStateToProps = state => ({ cmsNum: getCMSNum(state) });
const mapDispatchToProps = {setCMSId};
export default connect(mapStateToProps, mapDispatchToProps)(CMSForm);
添加回答
举报