我正在尝试使用Redux Form字段为Select标签设置一个初始值。
Redux字段:
<Field
name="statusDto.pkid"
component={renderSelectField}
type="text"
isHidden="true"
placeholder="Select Status"
options={userRegistrationStatus && userRegistrationStatus.map((values) => { return ({ value: values.pkid, label: i18next.languages[0] === 'en' ? values.enName : values.trName }); })}
/>
Redux表单:
UserRegistrationForm = reduxForm({
validate,
form: 'User_Registration_Form', // a unique identifier for this form
enableReinitialize: true,
})(UserRegistrationForm));
反应选择:
handleChange = (selectedOption) => {
const { onChange } = this.props;
this.setState({ selectedOptionState: selectedOption });
onChange(selectedOption.value);
};
<Select
name={name}
value={selectedOptionState}
onChange={this.handleChange}
styles={customStyles}
options={options}
clearable={false}
className="react-select"
placeholder={placeholder}
isDisabled={isDisabled}
classNamePrefix="react-select"
theme={(theme) => ({
...theme,
borderRadius: 0,
colors: {
...theme.colors,
primary: '#70bbfd',
},
})}
/>
使用redux-form初始化,我尝试将第一个值分配给react-select,但似乎不值得。你能帮我吗?
答案 0 :(得分:0)
我解决了这个问题。
反应选择:
<Select
name={name}
value={(value === '') ? null : options.find(obj => obj.value === value)}
onChange={this.handleChange}
styles={customStyles}
options={options}
clearable={false}
className="react-select"
placeholder={placeholder}
isDisabled={isDisabled}
classNamePrefix="react-select"
theme={(theme) => ({
...theme,
borderRadius: 0,
colors: {
...theme.colors,
primary: '#70bbfd',
},
})}
/>