КОНТЕКСТПередача значений через реквизит от React Stateless потомка к родителю
Я пытаюсь передать поля ввода значений (conditionTitle
) от React Stateless компоненты ребенка (AddConditionSelect
) в качестве родительского компонента (AddConditionDashboard
), который будет держите мое состояние.
ПРОБЛЕМА
Я следовал моделям, показанные в React documentation, но они используют реф, который работает только тогда, когда компонент с сохранением состояния. Я не хочу устанавливать какое-либо состояние в дочернем компоненте, но все равно иметь доступ к входу в родительском элементе.
В его текущей форме я получаю предупреждение о том, что компонентам функции без состояния не могут быть присвоены ссылки refs, в результате чего реквизиты являются нулевыми и неопределенными.
Родитель Компонент:
import AddConditionSelect from '../containers/AddConditionSelect.js';
class AddConditionDashboard extends React.Component {
constructor(props) {
super(props);
this.state = {
conditionTitle: '',
conditionType: ''
};
}
handleUserInput({conditionTitleInput}) {
this.setState({
conditionTitle:conditionTitle
})
}
render() {
const {error, segmentId} = this.props;
return (
<div>
<AddConditionSelect segmentId={segmentId} conditionTitle={this.state.conditionTitle} onUserInput={this.handleUserInput} />
<PanelFooter theme="default">
<Button backgroundColor="primary" color="white" inverted={true} rounded={true} onClick={(event) => this.onSubmit(event)}>
Next Step
</Button>
</PanelFooter>
</div>
);
}
}
export default AddConditionDashboard;
Детский компонент:
class AddConditionSelect extends React.Component {
onInputChange: function() {
this.props.onUserInput(
this.refs.conditionTitleInput.value,
)
},
render() {
const {error} = this.props;
return (
<div>
<Panel theme="info">
<Divider />
Please enter a name {error ? <Message inverted={true} rounded={true} theme="error">{error}</Message> : null}
<Input value={this.props.conditionTitle} ref="conditionTitleInput" label="" type="text" buttonLabel="Add Condition" name="add_segment" onChange={this.onInputChange} placeholder="Condition Title"/>
</Panel>
</div>
);
}
}
export default AddConditionSelect;
вы можете показать нам свой входной компонент? Это поможет. – QoP
Входной компонент - это только компонент Rebass - http://jxnblk.com/rebass/#Input – Dan