Атрибуты value селекта из массива в React

Пусть у нас опять пункты списка хранятся в массиве:

function App() { const texts = ['text1', 'text2', 'text3', 'text4']; const [value, setValue] = useState(''); ... }

Давайте сформируем с помощью этого массива теги option, добавив им в качестве атрибутов value значения элементов массива:

function App() { const texts = ['text1', 'text2', 'text3', 'text4']; const [value, setValue] = useState(''); const options = texts.map((text, index) => { return <option key={index} value={index}>{text}</option>; }); ... }

Используя сформированные теги создадим выпадающий список:

return <div> <select value={value} onChange={event => setValue(event.target.value)}> {options} </select> </div>;

Выведем в абзац номер выбранного пункта:

return <div> <select value={value} onChange={event => setValue(event.target.value)}> {options} </select> <p> ваш выбор: {value} </p> </div>;

А теперь выведем текст выбранного пункта, используя его номер и массив с текстами:

return <div> <select value={value} onChange={event => setValue(event.target.value)}> {options} </select> <p> ваш выбор: {texts[value]} </p> </div>;

Соберем все вместе и получим следующий код:

function App() { const texts = ['text1', 'text2', 'text3', 'text4']; const [value, setValue] = useState(''); const options = texts.map((text, index) => { return <option key={index} value={index}>{text}</option>; }); return <div> <select value={value} onChange={event => setValue(event.target.value)}> {options} </select> <p> ваш выбор: {texts[value]} </p> </div>; }



Чат с GPT Компилятор