组件正在将文本类型的非受控输入更改为ReactJS中的受控错误

警告:组件正在更改要控制的文本类型的非受控输入。输入元件不应从非受控切换到受控(反之亦然)。在组件的使用寿命内,决定使用受控或非受控输入元件*

以下是我的代码:

构造函数(道具){
超级(道具);
此.state={
字段:{},
错误:{}
}
this.onSubmit=this.onSubmit.bind(this);
}
....
onChange(字段,e){
让fields=this.state.fields;
字段[字段]=e.target.value;
this.setState({fields});
}
....
render(){
返回(
<div className=“表单组”>
<输入
值={this.state.fields[“name”]}
onChange={this.onChange.bind(this,“name”)}
className=“表单控件”
type=“text”
refs=“name”
占位符=“名称*”
/&燃气轮机;
<span style={{color:“red”}}>{this.state.errors[“name”]}</span>
</div>
)
}

原因是,在您定义的状态下:

this.state={fields:{}

字段作为空白对象,因此在第一次呈现期间,this.state.fields.name将是未定义的,输入字段将获得其值:

value={undefined}

因此,输入字段将变得不受控制

在输入中输入任何值后,状态中的字段将更改为:

this.state={fields:{name:'xyz'}

此时,输入字段被转换为受控组件;这就是为什么会出现错误:

组件正在将文本类型的非受控输入更改为
控制

可能的解决方案:

1-将状态中的字段定义为:

this.state={fields:{name:''}

2-或使用短路评估定义值属性,如下所示:

value={this.state.fields.name | |''}//(未定义| |'')=''

发表评论