我是一个新手后端开发人员,我的任务是修复一个功能,但我被困在反应部分。我似乎找不到合适的语法来从选择组件中获取值,这几乎是我的全部问题。我查看了许多其他帖子和 react 文档,但我正在尝试的没有任何工作。标记示例如下(此视图中有很多选择字段):
<div className="grid-content noscroll medium-6 small-12" style={{overflow: 'visible'}}>
<div className="grid-content"><label>Program</label></div>
<div className="grid-content" style={{overflow: 'visible'}}>
<Select
key="program_key"
ref="program_key"
multi={false}
value={ jobData && jobData.program_key ? jobData.program_key : null}
options={programOptions}
onChange={this.changeField.bind(null, 'program_key')}
/>
</div>
</div>
那么事件处理程序如下:
changeField: function(propName) {
var field = this.refs[propName].getDOMNode();
console.log(field.input);
console.log(field);
var nextProp = field.value.length > 0 ? field.value : null;
var job = Object.assign({}, this.state.job);
job.payload.data[propName] = nextProp;
if(propName === 'user_id') {
this.changeUserId = true
}
this.setState({
job: job,
updated: false
});
}
console.log(field) 的结果是:
<div class="Select is-searchable has-value" data-reactid=".0.0.2.0.1.0.1.1.0.1.1.$program_key">
<input type="hidden" value="NHDS" data-reactid=".0.0.2.0.1.0.1.1.0.1.1.$program_key.0">
它从那里继续,但'value =“NHDS”'是我需要的部分,我无法弄清楚如何在我的生活中得到它。如果我能澄清或改进这个问题,请告诉我。提前致谢。