Popper
Um Popper pode ser usado para exibir algum conteúdo em cima do outro. É uma alternativa para react-popper.
Algumas características importantes do componente Popper
:
- 🕷 Popper é baseado na biblioteca de terceiros (Popper.js) para um posicionamento perfeito.
- 💄 É uma API alternativa para react-popper. Visa a simplicidade.
- 📦 24.9 kB gzipped.
- The children is
Portal
to the body of the document to avoid rendering problems. Você pode desativar esse comportamento comdisablePortal
. - The scroll isn't blocked like with the
Popover
component. O posicionamento do popper é atualizado com a área disponível no visor. - Clicar fora não oculta o componente
Popper
. If you need this behavior, you can useClickAwayListener
- see the example in the menu documentation section. - O
anchorEl
é passado como o objeto de referência para criar uma nova instânciaPopper.js
.
A paleta com funções de estilo.
Popper Simples
Transições
O estado de aberto/fechado do popper pode ser animado com uma propriedade de renderização do elemento filho e um componente de transição. Este componente deve respeitar as seguintes condições:
- Ser um elemento filho descendente direto de popper.
- Chamar a propriedade de callback
onEnter
quando a transição de entrada iniciar. - Chamar a propriedade de callback
onExited
quando a transição de saída for concluída. Esses dois callbacks permitem que o popper desmonte o conteúdo filho quando fechado e seja totalmente transitado.
Popper possui suporte interno para react-transition-group.
Alternatively, you can use react-spring.
Scroll around this container to experiment with flip and preventOverflow modifiers.
Prevent Overflow
Flip
Arrow
<Popper
placement="bottom"
disablePortal={false}
modifiers={[
{
name: 'flip',
enabled: true,
options: {
altBoundary: true,
rootBoundary: 'document',
padding: 8,
},
},
{
name: 'preventOverflow',
enabled: true,
options: {
altAxis: true,
altBoundary: true,
tether: true,
rootBoundary: 'document',
padding: 8,
},
},
{
name: 'arrow',
enabled: false,
options: {
element: arrowRef,
},
},
]}
>
Elemento virtual
A propriedade anchorEl
pode ser uma referência a um elemento DOM falso. Você precisa criar um objeto com a estrutura definida como VirtualElement
.
Selecione parte do texto para ver o popper:
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam ipsum purus, bibendum sit amet vulputate eget, porta semper ligula. Donec bibendum vulputate erat, ac fringilla mi finibus nec. Donec ac dolor sed dolor porttitor blandit vel vel purus. Fusce vel malesuada ligula. Nam quis vehicula ante, eu finibus est. Proin ullamcorper fermentum orci, quis finibus massa. Nunc lobortis, massa ut rutrum ultrices, metus metus finibus ex, sit amet facilisis neque enim sed neque. Quisque accumsan metus vel maximus consequat. Suspendisse lacinia tellus a libero volutpat maximus.
Projetos Complementares
Para situações de uso mais avançadas, você pode tirar proveito com:
PopupState helper
Existe um pacote de terceiros material-ui-popup-state
que cuida do estado popover para você na maioria das situações.