Предположим, что у меня есть компонент вида, который имеет условный рендеринг:
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>
);
}
}
Допустим, что employed
истинно. Всякий раз, когда я переключаю его на false, а другой вид визуализации, только 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>
);
}
}
Кажется, все работает нормально. Похож, что "Реакт" просто не может отличить "название работы" и "причина безработицы".
Скажите, пожалуйста, что я делаю неправильно...