×
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.

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *

Autor

flpchapola@hotmail.com

Posts relacionados

OpenAI Quer Adquirir Chrome e Revolucionar Navegação com Experiência Centrada em Inteligência Artificial

OpenAI Quer Adquirir Chrome e Revolucionar Navegação com Experiência Centrada em Inteligência Artificial

Em uma movimentação recente no caso antitruste em andamento contra o Google, a OpenAI manifestou interesse em adquirir o navegador Chrome, caso...

Leia tudo
"Descubra o Momento Ideal para Contratar uma Assessoria de Carreira e Transforme Sua Trajetória Profissional!"

“Descubra o Momento Ideal para Contratar uma Assessoria de Carreira e Transforme Sua Trajetória Profissional!”

Contratar uma assessoria de carreira é uma decisão estratégica que pode impulsionar significativamente a sua trajetória profissional. Seja em momentos de transição,...

Leia tudo
Novidades Lovable 2025: Controle, Flexibilidade e Estabilidade para Desenvolvimento Ágil de Produtos Digitais

Novidades Lovable 2025: Controle, Flexibilidade e Estabilidade para Desenvolvimento Ágil de Produtos Digitais

Desbrave os passos à frente no mundo da inovação tecnológica com a Lovable em 2025. Projetada para otimizar o desenvolvimento de produtos...

Leia tudo
Cursor: Editor de Código com IA Agora Tem Abas de Chat, Modos Customizados e Indexação Acelerada

Cursor: Editor de Código com IA Agora Tem Abas de Chat, Modos Customizados e Indexação Acelerada

O Cursor, um inovador editor de código integrado com inteligência artificial, recentemente incrementou suas funcionalidades, permitindo que desenvolvedores melhorem drasticamente seu fluxo...

Leia tudo
10 anos de conselhos sobre programação: princípios essenciais para desenvolvedores

10 anos de conselhos sobre programação: princípios essenciais para desenvolvedores

## 10 anos de conselhos sobre programação em 60 segundos: princípios essenciais ### **Domine o Debugger** O debugger é sua maior aliada...

Leia tudo