<select>
O componente <select> nativo do navegador permite que você renderize uma caixa de seleção com opções.
<select>
<option value="someOption">Alguma opção</option>
<option value="otherOption">Outra opção</option>
</select>Referência
<select>
Para exibir uma caixa de seleção, renderize o componente <select> nativo do navegador.
<select>
<option value="someOption">Alguma opção</option>
<option value="otherOption">Outra opção</option>
</select>Props
<select> suporta todas as props de elementos gerais.
Você pode tornar uma caixa de seleção controlada passando a prop value:
value: Uma string (ou um array de strings paramultiple={true}). Controla qual opção está selecionada. Cada valor de string corresponde aovaluede algum<option>aninhado dentro do<select>.
Ao passar value, você deve também passar o manipulador onChange que atualize o valor passado.
Se o <select> for não controlado, você pode passar a prop defaultValue em vez disso:
defaultValue: Uma string (ou um array de strings paramultiple={true}). Especifica a opção selecionada inicialmente.
Essas props <select> são relevantes tanto para caixas de seleção controladas e não controladas:
autoComplete: Uma string. Especifica um dos possíveis comportamentos de preenchimento automático.autoFocus: Um booleano. Setrue, o React irá focar o elemento ao montar.children:<select>aceita os componentes<option>,<optgroup>e<datalist>como filhos. Você também pode passar seus próprios componentes, desde que eventualmente renderizam um dos componentes permitidos. Se passar seus próprios componentes, que eventualmente renderizem tags<option>, cada<option>que você renderize precisa ter umvalue.disabled: Um booleano. Setrue, a caixa de seleção não será interativa e aparecerá desativada.form: Uma string. Especifica oiddo<form>ao qual esta caixa de seleção pertence. Se omitido, será o formulário pai mais próximo.multiple: Um booleano. Iftrue, o navegador permite seleção múltipla.name: Uma string. Especifica o nome desta caixa de seleção que é enviado com o formulário.onChange: Uma função de manipulador deEvent. Necessário para caixas de seleção controladas. Dispara imediatamente quando o usuário escolhe uma opção diferente. Se comporta como o evento deinputdo navegador.onChangeCapture: Uma versão deonChangeque dispara na fase de captura.onInput: Uma função de manipulador deEvent. Dispara imediatamente quando o valor é alterado pelo usuário. Por razões históricas, é comum usaronChangeno React, que funciona de forma similar.onInputCapture: Uma versão deonInputque dispara na fase de captura.onInvalid: Uma função de manipulador deEvent. Dispara se uma entrada falha na validação ao enviar o formulário. Diferente do eventoinvalidnativo, o eventoonInvaliddo React é propagado.onInvalidCapture: Uma versão deonInvalidque dispara na fase de captura.required: Um booleano. Setrue, o valor deve ser fornecido para o envio do formulário.size: Um número. Para selectsmultiple={true}selects, especifica o número preferencial de itens visíveis inicialmente.
Ressalvas
- Diferente do HTML, passar um atributo
selectedpara<option>não é suportado. Em vez disso, use<select defaultValue>para caixas de seleção não controladas e<select value>para caixas de seleção controladas. - Se uma caixa de seleção receber a prop
value, ela será tratada como controlada. - Uma caixa de seleção não pode ser simultaneamente controlada e não controlada.
- Uma caixa de seleção não pode alternar entre ser controlada e não controlada durante sua vida útil.
- Toda caixa de seleção controlada precisa de um manipulador de eventos
onChangeque atualize seu valor de forma síncrona.
Uso
Exibindo uma caixa de seleção com opções
Renderize um <select> com uma lista de componentes <option> dentro para exibir uma caixa de seleção. Dê a cada <option> um value que represente os dados a serem enviados com o formulário.
export default function FruitPicker() { return ( <label> Escolha uma fruta: <select name="selectedFruit"> <option value="apple">Maçã</option> <option value="banana">Banana</option> <option value="orange">Laranja</option> </select> </label> ); }
Fornecendo um rótulo para uma caixa de seleção
Normalmente, você colocará cada <select> dentro de uma tag <label>. Isso informa ao navegador que esse rótulo está associado a essa caixa de seleção. Quando o usuário clica no rótulo, o navegador automaticamente foca na caixa de seleção. Isso também é essencial para acessibilidade: um leitor de tela anunciará a legenda do rótulo quando o usuário focar na caixa de seleção.
If you can’t nest <select> into a <label>, associate them by passing the same ID to <select id> and <label htmlFor>. To avoid conflicts between multiple instances of one component, generate such an ID with useId.
import { useId } from 'react'; export default function Form() { const vegetableSelectId = useId(); return ( <> <label> Pick a fruit: <select name="selectedFruit"> <option value="apple">Apple</option> <option value="banana">Banana</option> <option value="orange">Orange</option> </select> </label> <hr /> <label htmlFor={vegetableSelectId}> Pick a vegetable: </label> <select id={vegetableSelectId} name="selectedVegetable"> <option value="cucumber">Cucumber</option> <option value="corn">Corn</option> <option value="tomato">Tomato</option> </select> </> ); }
Providing an initially selected option
By default, the browser will select the first <option> in the list. To select a different option by default, pass that <option>’s value as the defaultValue to the <select> element.
export default function FruitPicker() { return ( <label> Pick a fruit: <select name="selectedFruit" defaultValue="orange"> <option value="apple">Apple</option> <option value="banana">Banana</option> <option value="orange">Orange</option> </select> </label> ); }
Enabling multiple selection
Pass multiple={true} to the <select> to let the user select multiple options. In that case, if you also specify defaultValue to choose the initially selected options, it must be an array.
export default function FruitPicker() { return ( <label> Pick some fruits: <select name="selectedFruit" defaultValue={['orange', 'banana']} multiple={true} > <option value="apple">Apple</option> <option value="banana">Banana</option> <option value="orange">Orange</option> </select> </label> ); }
Reading the select box value when submitting a form
Add a <form> around your select box with a <button type="submit"> inside. It will call your <form onSubmit> event handler. By default, the browser will send the form data to the current URL and refresh the page. You can override that behavior by calling e.preventDefault(). Read the form data with new FormData(e.target).
export default function EditPost() { function handleSubmit(e) { // Prevent the browser from reloading the page e.preventDefault(); // Read the form data const form = e.target; const formData = new FormData(form); // You can pass formData as a fetch body directly: fetch('/some-api', { method: form.method, body: formData }); // You can generate a URL out of it, as the browser does by default: console.log(new URLSearchParams(formData).toString()); // You can work with it as a plain object. const formJson = Object.fromEntries(formData.entries()); console.log(formJson); // (!) This doesn't include multiple select values // Or you can get an array of name-value pairs. console.log([...formData.entries()]); } return ( <form method="post" onSubmit={handleSubmit}> <label> Pick your favorite fruit: <select name="selectedFruit" defaultValue="orange"> <option value="apple">Apple</option> <option value="banana">Banana</option> <option value="orange">Orange</option> </select> </label> <label> Pick all your favorite vegetables: <select name="selectedVegetables" multiple={true} defaultValue={['corn', 'tomato']} > <option value="cucumber">Cucumber</option> <option value="corn">Corn</option> <option value="tomato">Tomato</option> </select> </label> <hr /> <button type="reset">Reset</button> <button type="submit">Submit</button> </form> ); }
Controlling a select box with a state variable
A select box like <select /> is uncontrolled. Even if you pass an initially selected value like <select defaultValue="orange" />, your JSX only specifies the initial value, not the value right now.
To render a controlled select box, pass the value prop to it. React will force the select box to always have the value you passed. Typically, you will control a select box by declaring a state variable:
function FruitPicker() {
const [selectedFruit, setSelectedFruit] = useState('orange'); // Declare a state variable...
// ...
return (
<select
value={selectedFruit} // ...force the select's value to match the state variable...
onChange={e => setSelectedFruit(e.target.value)} // ... and update the state variable on any change!
>
<option value="apple">Apple</option>
<option value="banana">Banana</option>
<option value="orange">Orange</option>
</select>
);
}This is useful if you want to re-render some part of the UI in response to every selection.
import { useState } from 'react'; export default function FruitPicker() { const [selectedFruit, setSelectedFruit] = useState('orange'); const [selectedVegs, setSelectedVegs] = useState(['corn', 'tomato']); return ( <> <label> Pick a fruit: <select value={selectedFruit} onChange={e => setSelectedFruit(e.target.value)} > <option value="apple">Apple</option> <option value="banana">Banana</option> <option value="orange">Orange</option> </select> </label> <hr /> <label> Pick all your favorite vegetables: <select multiple={true} value={selectedVegs} onChange={e => { const options = [...e.target.selectedOptions]; const values = options.map(option => option.value); setSelectedVegs(values); }} > <option value="cucumber">Cucumber</option> <option value="corn">Corn</option> <option value="tomato">Tomato</option> </select> </label> <hr /> <p>Your favorite fruit: {selectedFruit}</p> <p>Your favorite vegetables: {selectedVegs.join(', ')}</p> </> ); }