Slider
Sliders permitem que os usuários façam seleções a partir de um intervalo de valores.
Sliders refletem um intervalo de valores ao longo de uma barra, a partir do qual os usuários podem selecionar um único valor. Eles são ideais para ajustar configurações como volume, brilho ou aplicação de filtros de imagem.
- 📦 22 kB gzipped (mas apenas +8 kB quando usado junto com outros componentes de Material-UI).
Sliders contínuos
Os sliders contínuos permitem que os usuários selecionem um valor ao longo de um intervalo subjetivo.
Volume
Disabled slider
Sliders discretos
Os sliders discretos podem ser ajustados para um valor específico, fazendo referência ao seu indicador de valor. Por ordem de demonstrações:
Você pode gerar uma marca para cada etapa com marks={true}
.
Temperature
Disabled
Small steps
<Typography id="discrete-slider-small-steps" gutterBottom>
Small steps
</Typography>
<Slider
defaultValue={0.00000005}
getAriaValueText={valuetext}
aria-labelledby="discrete-slider-small-steps"
step={0.00000001}
marks
min={-0.00000005}
max={0.0000001}
valueLabelDisplay="auto"
/>
Marcas personalizadas
Você pode ter marcas customizadas, fornecendo um array para a propriedade marks
.
Custom marks
<Typography id="discrete-slider-custom" gutterBottom>
Custom marks
</Typography>
<Slider
defaultValue={20}
getAriaValueText={valuetext}
aria-labelledby="discrete-slider-custom"
step={10}
valueLabelDisplay="auto"
marks={marks}
/>
Valores restritos
Você pode restringir os valores selecionáveis fornecidos na propriedade marks
configurando a propriedade step={null}
.
Restricted values
<Typography id="discrete-slider-restrict" gutterBottom>
Restricted values
</Typography>
<Slider
defaultValue={20}
valueLabelFormat={valueLabelFormat}
getAriaValueText={valuetext}
aria-labelledby="discrete-slider-restrict"
step={null}
valueLabelDisplay="auto"
marks={marks}
/>
Always visible
<Typography id="discrete-slider-always" gutterBottom>
Always visible
</Typography>
<Slider
defaultValue={80}
getAriaValueText={valuetext}
aria-labelledby="discrete-slider-always"
step={10}
marks={marks}
valueLabelDisplay="on"
/>
Slider com intervalo
O slider pode ser usado para definir o início e o fim de um intervalo, fornecendo um array de valores para a propriedade value
.
Temperature range
<Typography id="range-slider-demo" gutterBottom>
Temperature range
</Typography>
<Slider
value={value}
onChange={handleChange}
valueLabelDisplay="auto"
aria-labelledby="range-slider-demo"
getAriaValueText={valuetext}
/>
Volume
Sliders customizados
Aqui estão alguns exemplos de customização do componente. Você pode aprender mais sobre isso na página de documentação de sobrescritas.
iOS
pretto.fr
Tooltip value label
Airbnb
Temperature
WARNING: Chrome, Safari and newer Edge versions i.e. any browser based on WebKit exposes <Slider orientation="vertical" />
as horizontal (chromium issue #1158217). By applying -webkit-appearance: slider-vertical;
the slider is exposed as vertical.
However, by applying -webkit-appearance: slider-vertical;
keyboard navigation for horizontal keys (Arrow Left, Arrow Right) is reversed (chromium issue #1162640). Usually, up and right should increase and left and down should decrease the value. If you apply -webkit-appearance
you could prevent keyboard navigation for horizontal arrow keys for a truly vertical slider. This might be less confusing to users compared to a change in direction.
Temperature
Faixa
A faixa exibe o intervalo disponível para a seleção do usuário.
Faixa desabilitada
A faixa pode ser desabilitada com track={false}
.
Removed track
Removed track range slider
Inverted track
Inverted track range
Escala não linear
Você pode usar a propriedade scale
para representar o value
em uma escala diferente.
Na seguinte demonstração, o valor x representa o valor 2^x. Acrescentar em x aumenta o valor representado por fator de 2.
Storage: 1 MB
<Typography id="non-linear-slider" gutterBottom>
Storage: {valueLabelFormat(calculateValue(value))}
</Typography>
<Slider
value={value}
min={5}
step={1}
max={30}
scale={calculateValue}
getAriaValueText={valueLabelFormat}
valueLabelFormat={valueLabelFormat}
onChange={handleChange}
valueLabelDisplay="auto"
aria-labelledby="non-linear-slider"
/>
<StyledSlider defaultValue={10} />
Acessibilidade
(WAI-ARIA: https://www.w3.org/TR/wai-aria-practices/#slider)
O componente lida com a maior parte do trabalho necessário para torná-lo acessível. No entanto, você precisa se certificar de que:
- Cada marcador possua propriedades de rótulo amigável para o usuário (
aria-label
,aria-labelledby
ougetAriaLabel
). - Cada marcador tenha um texto amigável para o seu valor atual. Isso não é necessário se o valor corresponder ao rótulo exibido no slider. Você pode alterar o nome com as propriedades
getAriaValueText
ouaria-valuetext
.