Ну, я бы рекомендовал передать функцию модификатора состояния компоненту <select>
и добавить обработчик события для onchange
.
Пример
export default class Contact extends React.Component {
constructor(props) {
super(props)
this.state = {
btnColor: '[White, Silver, Grey, Black, Orange, Brown, Maroon, Green, Olive, Red, Cyan, Blue, DarkBlue, LightBlue, Purple, Yellow, Lime, Magenta]',
submitted: false,
selected: ''
}
selectHandler = (event) => {
this.setState({submitted: true, selected: event.target.value});
}
function render() {
<FormSelect onSelect={onSelect} />
}
}
И компонент select:
const FormSelect = ({
name,
type,
placeholder,
onChange,
className,
value,
error,
children,
label,
btnColor,
onSelect,
...props}) => {
return (
<div className={className}>
<label htmlFor={name}>{label}</label>
<select onchange={onSelect}>
<option
id={name}
name={name}
type={type}
placeholder={placeholder}
onChange={onChange}
value={btnColor.map(btnColor)}
/>
</select>
</div>
)}
Обратите внимание, что в компоненте Contact
я добавил новое состояние selected
, в котором будет сохранено выбранное значение после запуска события onchange
.