问题描述
我在 react 中实现表单输入验证时遇到了问题。 一旦我打开表单,总是有 [object object] 作为默认输入出现。 这是显示:
理想情况下,我希望有以下显示:
这是我的代码,知道我该如何修复吗?
const ErrorValidationLabel = ({ txtLbl }) => (
<label htmlFor="" style={{ color: "red" }}>
{txtLbl}
</label>
);
const txtFieldState = {
value: "",valid:true,}
class Setting extends Component {
constructor() {
this.state = {
name: {...txtFieldState,fileName:"name",required:true,requiredTxt:"Device ID is required"},}
this.handleNameChange = this.handleNameChange.bind(this);
this.handleNameSearch = this.handleNameSearch.bind(this);
handleNameChange(event) {
this.setState({ name: event.target.value });
}
handleNameSearch(event) {
//http request call logic
}
}
render() {
const renderNameError = this.state.name.valid? "" : <ErrorValidationLabel txtLbl={this.state.name.requiredTxt} />;
return (
<form onSubmit={this.handleNameSearch}>
<label >
Enter Your Device Id:
</label>
<Input name="name" type="text" placeholder="ex:12345678910" value={this.state.name} onChange={this.handleNameChange} required/>
{renderNameError}
<Input type="submit" value="Search Device" />
</form>
);
}
解决方法
您将输入的值设置为 this.state.name
,但 this.state.name
是一个对象。
this.state = {
name: {...txtFieldState,fileName:"name",required:true,requiredTxt:"Device ID is required"}
}
您应该将其设置为 this.state.name.value
。
但是,我应该警告您,代码 this.setState({ name: event.target.value })
将覆盖您的整个 name
对象,这可能不是您想要的。
您已经在使用扩展运算符,所以我建议
this.setState(state => ({ name: { ...state.name,value: event.target.value } }))`.