React,React Redux,Redux表单类型无效
问题描述:
我有这个问题,无法解决它。React,React Redux,Redux表单类型无效
这里是我的代码:
import React from 'react';
import {withRouter} from 'react-router-dom';
import {Field, reduxForm} from 'redux-form';
import {connect} from 'react-redux';
import {RenderField} from 'modules/shared/components/RenderField';
class Register extends React.Component {
handleFormSubmit(data){
console.log(data);
}
render() {
const {handleSubmit} = this.props;
return (
<div className="form-popup">
<div className="form-popup-content">
<h4 className="popup-title">Daftar Baru</h4>
<hr className="line-separator"/>
<form id="register-form" name="registerForm" method="POST" onSubmit={handleSubmit(this.handleFormSubmit.bind(this))}>
<Field name="name" type="text" component={RenderField} label="Name"/>
<button type="submit" id="register-button" className="button mid dark ladda-button"
data-style="expand-right">
Register
</button>
</form>
</div>
</div>
);
}
}
function mapStateToProps(state){
return state;
}
Register = reduxForm({
form: 'registerForm',
})(Register);
export default withRouter(connect(mapStateToProps, null))(Register);
编译,我得到这个错误:
Warning: React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: object.
任何解决方案?
答
(Register)
应该在connect()
之后。
变化
export default withRouter(connect(mapStateToProps, null))(Register);
到
export default withRouter(connect(mapStateToProps, null)(Register));
OMG!傻我没有意识到这一点!感谢女王的痛苦:D – ssuhat
不客气!很高兴看到StackOverflow上有Dota玩家 – QoP