Neste artigo você aprenderá a como deixar uma option selecionada no React JS, uma ação muito comum nos projetos web!

Fala programador(a), beleza? Bora aprender mais sobre React!
O controle de formulários é um aspecto essencial em muitas aplicações web.
Neste artigo, vamos explorar uma questão comum enfrentada por muitos desenvolvedores React: como deixar uma opção selecionada por padrão em um elemento select?
Se você está familiarizado com HTML, você pode se perguntar: “não posso apenas adicionar o atributo selected a uma opção?”
No React, no entanto, as coisas funcionam um pouco diferente. Vamos discutir o porquê e como lidar com isso.
O Elemento Select no React
Em HTML padrão, o atributo ‘selected’ é usado para definir a opção padrão em um elemento select. No React, no entanto, o valor do select é controlado pelo estado do componente.
Isso significa que o valor selecionado deve ser definido no estado do componente e depois vinculado ao elemento select.
Assim, o React controla o estado do elemento select, tornando-o um componente controlado.
Aqui está um exemplo básico de como um elemento select pode ser renderizado em um componente funcional React com Hooks:
import React, { useState } from 'react';
const SelectExample = () => {
const [selectedOption, setSelectedOption] = useState('');
const handleChange = (event) => {
setSelectedOption(event.target.value);
}
return (
<select value={selectedOption} onChange={handleChange}>
<option value="">Selecione...</option>
<option value="option1">Opção 1</option>
<option value="option2">Opção 2</option>
<option value="option3">Opção 3</option>
</select>
);
}
Definindo uma opção pré-selecionada
Se você deseja ter uma opção pré-selecionada quando o componente for renderizado, você pode simplesmente definir o estado inicial para o valor dessa opção.
Aqui está como você pode fazer isso:
import React, { useState } from 'react';
const SelectExample = () => {
const [selectedOption, setSelectedOption] = useState('option2');
const handleChange = (event) => {
setSelectedOption(event.target.value);
}
return (
<select value={selectedOption} onChange={handleChange}>
<option value="option1">Opção 1</option>
<option value="option2">Opção 2</option>
<option value="option3">Opção 3</option>
</select>
);
}
Neste exemplo, a opção “Opção 2” estará selecionada por padrão quando o componente for renderizado, porque o estado inicial ‘selectedOption’ é definido como ‘option2’.
Lidando com múltiplas opções selecionadas
Se você deseja permitir que múltiplas opções sejam selecionadas, você pode fazer isso alterando o elemento select para aceitar múltiplos valores e alterando o estado para armazenar um array de opções selecionadas.
import React, { useState } from 'react';
const SelectExample = () => {
const [selectedOptions, setSelectedOptions] = useState(['option1', 'option2']);
const handleChange = (event) => {
const selected = Array.from(event.target.options)
.filter(option => option.selected)
.map(option => option.value);
setSelectedOptions(selected);
}
return (
<select multiple={true} value={selectedOptions} onChange={handleChange}>
<option value="option1">Opção 1</option>
<option value="option2">Opção 2</option>
<option value="option3">Opção 3</option>
</select>
);
}
Neste exemplo, as opções ‘Opção 1’ e ‘Opção 2’ estarão selecionadas por padrão, porque o estado inicial ‘selectedOptions’ é definido como [‘option1’, ‘option2’].
Trabalhando com dados dinâmicos
Agora que temos uma compreensão básica de como deixar uma opção selecionada no React, é importante mencionar que muitas vezes você estará trabalhando com dados dinâmicos.
Por exemplo, as opções em seu elemento select podem ser originárias de uma chamada de API.
Nesse caso, o estado inicial pode não estar disponível imediatamente. Assim, o valor inicial do estado pode ser definido como null ou vazio, e então alterado uma vez que os dados estejam disponíveis.
import React, { useState, useEffect } from 'react';
const SelectExample = () => {
const [selectedOption, setSelectedOption] = useState('');
const [options, setOptions] = useState([]);
useEffect(() => {
// Simulando uma chamada de API
setTimeout(() => {
setOptions(['option1', 'option2', 'option3']);
setSelectedOption('option2');
}, 2000);
}, []);
const handleChange = (event) => {
setSelectedOption(event.target.value);
}
return (
<select value={selectedOption} onChange={handleChange}>
{options.map((option, index) => <option key={index} value={option}>{option}</option>)}
</select>
);
}
Seleção de Opções Aninhadas
Outra situação comum é ter que gerenciar a seleção de opções aninhadas, onde a seleção de uma opção determina as opções disponíveis em uma seleção subsequente.
Neste caso, o estado inicial de ambas as seleções pode ser vazio e, em seguida, o estado da segunda seleção pode ser alterado com base na seleção da primeira.
import React, { useState } from 'react';
const SelectExample = () => {
const [firstSelection, setFirstSelection] = useState('');
const [secondSelection, setSecondSelection] = useState('');
const [secondOptions, setSecondOptions] = useState([]);
const firstOptions = ['option1', 'option2', 'option3'];
const handleChangeFirst = (event) => {
setFirstSelection(event.target.value);
// Defina as opções de segunda seleção com base na primeira seleção
switch (event.target.value) {
case 'option1':
setSecondOptions(['option1.1', 'option1.2']);
break;
case 'option2':
setSecondOptions(['option2.1', 'option2.2']);
break;
case 'option3':
setSecondOptions(['option3.1', 'option3.2']);
break;
default:
setSecondOptions([]);
}
}
const handleChangeSecond = (event) => {
setSecondSelection(event.target.value);
}
return (
<div>
<select value={firstSelection} onChange={handleChangeFirst}>
{firstOptions.map((option, index) => <option key={index} value={option}>{option}</option>)}
</select>
<select value={secondSelection} onChange={handleChangeSecond}>
{secondOptions.map((option, index) => <option key={index} value={option}>{option}</option>)}
</select>
</div>
);
}
Quer aprender mais sobre programação? Conheça nosso canal no YouTube:
Conclusão
Chegamos ao fim do artigo sobre como deixar a option selecionada no React JS!
A seleção de opções em um elemento select no React é um pouco diferente do que você pode estar acostumado com o HTML padrão, mas com a compreensão do conceito de componentes controlados, fica bastante simples.
Ao gerenciar o valor selecionado através do estado do componente, você pode ter um controle mais preciso sobre o comportamento do seu formulário, permitindo uma experiência de usuário mais fluida e reativa.
Está buscando em evoluir como Programador? Confira o nossos cursos de programação.