如何在 React 组件上强制重新挂载?
假设我有一个具有条件呈现的视图组件:
render(){
if (this.state.employed) {
return (
<div>
<MyInput ref="job-title" name="job-title" />
</div>
);
} else {
return (
<div>
<MyInput ref="unemployment-reason" name="unemployment-reason" />
<MyInput ref="unemployment-duration" name="unemployment-duration" />
</div>
);
}
}
MyInput 看起来像这样:
class MyInput extends React.Component {
...
render(){
return (
<div>
<input name={this.props.name}
ref="input"
type="text"
value={this.props.value || null}
onBlur={this.handleBlur.bind(this)}
onChange={this.handleTyping.bind(this)} />
</div>
);
}
}
让我们说这是真的。每当我将其切换为 false 并且其他视图呈现时,只会重新初始化。还会使用 from 中的值进行预填充(如果在条件更改之前给出了值)。employed
unemployment-duration
unemployment-reason
job-title
如果我将第二个呈现例程中的标记更改为如下所示:
render(){
if (this.state.employed) {
return (
<div>
<MyInput ref="job-title" name="job-title" />
</div>
);
} else {
return (
<div>
<span>Diff me!</span>
<MyInput ref="unemployment-reason" name="unemployment-reason" />
<MyInput ref="unemployment-duration" name="unemployment-duration" />
</div>
);
}
}
似乎一切都很好。看起来 React 只是无法区分“职位名称”和“失业原因”。
请告诉我我做错了什么...