Utilizando a API Popover: Simplificando Janelas Modais em Seu DOM com HTML e JavaScript
A API de Popover é uma adição recente ao HTML e JavaScript, trazendo um conjunto de APIs e atributos HTML que ajudam a criar janelas “modais” dentro do seu DOM de maneira simplificada. Esta funcionalidade é especialmente útil para diversas características, tais como:
- Caixas de login popup
- Mensagens Toast
- Sidebars de menu
Tradicionalmente, esses elementos exigiriam bastante CSS, incluindo posicionamento absoluto e gerenciamento de z-index. Contudo, a API de Popover simplifica significativamente esse processo.
Declarando Elementos Popover
Os elementos popover são declarados definindo o atributo popover no HTML. Esse atributo pode ser usado em conjunto com outros atributos para controlar o comportamento do popover.
Configuração Declarativa
Você pode configurar um popover de forma declarativa usando o atributo HTML popovertarget. Este atributo especifica qual popover deve ser aberto ou alternado. Por exemplo:
<button id="toggleBtn" popovertarget="mypopover">Alternar Popover</button>
<div id="mypopover" popover="auto">Conteúdo do Popover</div>
Configuração Programática
Alternativamente, você pode configurar um popover de forma programática usando métodos JavaScript. Aqui está um exemplo de como fazê-lo:
const popover = document.getElementById("mypopover");
const toggleBtn = document.getElementById("toggleBtn");
const popoverSupported = supportsPopover();
if (popoverSupported) {
popover.popover = "auto";
toggleBtn.popoverTargetElement = popover;
toggleBtn.popoverTargetAction = "toggle";
} else {
console.log("API de Popover não suportada.");
}
Visite este recurso para aprender mais sobre como implementar a API de Popover de forma eficaz.
Controlando o Comportamento do Popover
A API de Popover permite controlar o comportamento dos popovers através de vários métodos, incluindo:
- Dispensa Leve: No estado automático, o popover pode ser “dispensado levemente” ao clicar fora dele ou pressionar a tecla Esc.
- Vários Popovers: Geralmente, apenas um popover automático pode ser exibido de cada vez, mas há exceções para popovers automáticos aninhados.
- Estado Manual: No estado manual, o popover não pode ser “dispensado levemente”, embora botões declarativos de mostrar/ocultar/alternar ainda funcionem. Vários popovers independentes podem ser exibidos simultaneamente.
Uso de Exemplo
Aqui está um exemplo mais detalhado de como configurar um popover programaticamente:
function supportsPopover() {
return HTMLElement.prototype.hasOwnProperty("popover");
}
// Obter elementos
const popover = document.getElementById("mypopover");
const toggleBtn = document.getElementById("toggleBtn");
// Verificar se a API de Popover é suportada
const popoverSupported = supportsPopover();
if (popoverSupported) {
// Configurar atributos do popover
popover.popover = "auto";
toggleBtn.popoverTargetElement = popover;
toggleBtn.popoverTargetAction = "toggle";
} else {
// Tratar caso não suportado
toggleBtn.style.display = "none";
}
Para mais exemplos e casos de uso, confira este artigo sobre a API de Popover.
Funcionalidades Adicionais
Além disso, a API de Popover inclui vários exemplos e casos de uso, como:
- Exemplo Básico de Popover Declarativo: Demonstra um popover em estado automático básico.
- Exemplo de Desfocar o Plano de Fundo do Popover: Mostra como você pode adicionar estilização ao conteúdo por trás do popover usando o pseudo-elemento
::backdrop. - Exemplo de Vários Popovers Automáticos: Demonstra que, geralmente, apenas um popover automático pode ser exibido de uma vez.
- Exemplo de Vários Popovers Manuais: Demonstra que vários popovers manuais podem ser exibidos simultaneamente, mas não podem ser dispensados levemente.
Aproveitando a API de Popover, os desenvolvedores podem reduzir significativamente a quantidade de código necessária para criar janelas de estilo modal, tornando suas aplicações mais eficientes e fáceis de manter.
Autor
flpchapola@hotmail.com
Posts relacionados
Por que eu não gosto de Scrum (e o que uso no lugar)
Eu sou o Felipe Vieira e neste texto eu quero explicar, de forma franca e prática, por que o Scrum deixou de funcionar...
Leia tudo
OpenAI DevDay 2025: como eu vejo o futuro do desenvolvimento
Eu abro este texto com a mesma energia com que subi ao palco em San Francisco: empolgado, prático e com a certeza...
Leia tudo
Por Que O Último Programador Esqueceu o Teclado: Caminhos Surpreendentes do Futuro da Programação
Nem todo mundo vai ser substituído por máquinas — mas quem não se reinventa, corre sim o risco de virar história. O...
- Automação
- Automação e empregos em tecnologia
- Carreira
- Codificação
- Desafios
- desenvolvedores
- Desenvolvimento
- Desenvolvimento de aplicativos com IA
- Desenvolvimento sustentável de software
- Engenharia de IA e MLOps
- ferramentas de IA
- Futuro da programação 2025
- Git
- GitHub
- IA
- Inovação
- Inteligência Artificial
- Inteligência artificial integrada
- Plataformas low-code no-code
- Profissionais híbridos em tecnologia
- programação
- segurança
- Soluções
- Tecnologia
- Tendências de carreira em tecnologia
- Transformação do papel do programador
5 Estratégias para Desenvolvedores em 2025: IA, Fundamentos, Soft Skills, Buildar em Público e T-Shaped
## 5 Estratégias essenciais para potencializar sua carreira de desenvolvedor em 2025 O avanço tecnológico avassalador está remodelando o cenário do desenvolvimento...
Guia Completo para Entrevistas de Design de Sistemas: Da Teoria à Prática Avançada
Guia Definitivo para Entrevistas de Design de Sistemas: Dos Fundamentos à Arquitetura Avançada As entrevistas de design de sistemas tornaram-se fundamentais no...
Leia tudoTroquei o Cursor! Qoder NOVA IDE de IA do Alibaba — vibecoding cursor bolt lovable replit ai
Eu sou o Felipe DEV e, se você viu o meu conteúdo, sabe que eu sempre testo ferramentas de IA para desenvolvimento....
Leia tudo