Padrões de apps da Web
Uma coleção de padrões comuns para a criação de aplicativos da Web.
- O Promise.try está disponível como padrão
- Detecção de recursos da WebAuthn mais simples com getClientCapabilities()
- Crie um chatbot local e off-line com o WebLLM
- Benefícios e limites dos modelos de linguagem grandes
- Criar um chatbot local e off-line com a API Prompt
- Criar chatbots locais e com capacidade off-line
- Otimizar tarefas longas
- Aplicar efeitos a imagens com a propriedade mask-image do CSS
- Valor de referência de 2024: mais ferramentas para ajudar desenvolvedores da Web
- Vídeo de carregamento lento
- Pré-carregar módulos
- Medir o preenchimento automático do navegador nos formulários
- Parte 1: IA do lado do cliente para combater a toxicidade on-line
- Parte 2: criar a detecção de toxicidade da IA do lado do cliente
- Tempo total de bloqueio (TBT)
- Web Vitals
- Começar a medir as Web Vitals
- As maneiras mais eficazes de melhorar as Core Web Vitals
- Otimizar a Maior exibição de conteúdo
- Comparar o recurso de LLM com o resumo
- A propriedade content-visibility do CSS agora está disponível como padrão
- Como os limites das Core Web Vitals foram definidos
- Diagnosticar manualmente as interações lentas no laboratório
- Fluxos de trabalho das Principais métricas da Web com ferramentas do Google
- Referência
- Cache de avanço e retorno
- O aninhamento de CSS foi aprimorado com CSSNestedDeclarations.
- Depurar o desempenho no campo
- First Input Delay (FID)
- Comparativo de mercado da performance da @property do CSS
- Correlação das Core Web Vitals e receita de publicidade com as ferramentas do Google
- Melhore a performance e a UX da IA do lado do cliente
- Armazenamento para a Web
- É hora de carregar lentamente iframes fora da tela.
- O protocolo de push na Web
- Como criar vários Progressive Web Apps no mesmo domínio
- Quais são as características de um bom Progressive Web App?
- O que é necessário para a instalação?
- Como o Chrome lida com as atualizações no manifesto do app da Web
- Adicionar um manifesto de app da Web
- Reduza o scripting em vários locais (XSS) com uma Política de Segurança de Conteúdo (CSP) rígida
- Como acessar dispositivos de hardware na web
- Permitir a reutilização da chave de acesso nos seus sites com solicitações de origem relacionadas
- Escolha o formato de imagem correto
- Carregamento lento de imagens no navegador para a Web
- Métricas personalizadas
- Meça e depure a performance com o Google Analytics 4 e o BigQuery
- Práticas recomendadas de permissões da Web
- Práticas recomendadas para avisos de cookies
- Personalize notificações de mídia e controles de mídia com a API Media Session
- Como usar o tabindex
- Encontrar interações lentas no campo
- Tempo até o primeiro byte (TTFB)
- Engenharia de comandos prática para LLMs menores
- Interação com Próxima Exibição (INP)
- Cores dependentes do esquema de cores CSS com light-dark()
- Padrões de desempenho do WebAssembly para apps da Web
- Layouts de grade animada em CSS
- Curta o jogo do dinossauro do Chrome com seu gamepad
- O atributo inert
- O que é inteligência artificial?
- Ética e IA
- Conheça a equipe de IA do Web.dev
- Upgrade da pesquisa no site: respostas contextuais com a IA generativa
- Determinar o provedor da chave de acesso com o AAGUID
- Como compilar e otimizar o Wasm com Binaryen
- O componente da Web <model-viewer>
- Captura de áudio e vídeo em HTML5
- Análise detalhada de userverification
- Por que os dados do CrUX são diferentes dos meus dados do RUM?
- Acessibilidade para desenvolvedores da Web
- Carregar JavaScript de terceiros
- Largest Contentful Paint (LCP)
- Impedir a criação de uma nova chave de acesso, se já houver uma
- Trabalhar com IndexedDB
- 5 snippets de CSS que todos os desenvolvedores front-end precisam saber em 2024
- Otimizar o tempo para o primeiro byte
- Quais são as partes de um URL?
- Análise detalhada das credenciais detectáveis
- Desempenho de renderização
- ResizeObserver: é como document.onresize para elementos.
- Otimizar a codificação e o tamanho da transferência de recursos baseados em texto
- OffscreenCanvas: agilize suas operações com um web worker
- First Contentful Paint (FCP)
- Redes de fornecimento de conteúdo (CDNs)
- O que resulta em uma boa experiência de logout?
- Tempo para interação da página (TTI)
- Otimizar o carregamento de recursos com a API Fetch Preview
- As pseudoclasses :user-valid e :user-invalid
- Otimizar as Core Web Vitals para os tomadores de decisão de negócios
- As nuances das strings de codificação base64 no JavaScript
- Subgrade CSS
- Como carregar anúncios de maneira eficaz sem afetar a velocidade da página
- Quatro tipos comuns de cobertura de código
- Testar ou não: do ponto de vista técnico
- Como definir casos de teste e prioridades
- Métricas de performance centradas no usuário
- Pré-carregar imagens responsivas
- Como adaptar a tipografia às preferências do usuário com CSS
- Pirâmide ou caranguejo? Encontre uma estratégia de teste adequada
- Três tipos comuns de automação de testes
- Eliminar downloads desnecessários
- Como compilar mkbitmap para WebAssembly
- O que é o WebAssembly e de onde ele veio?
- O sistema de arquivos privados de origem
- Hospede com segurança dados do usuário em aplicativos da Web modernos
- Como implantar o AVIF em sites mais responsivos
- Otimizar a interação com a próxima exibição
- Recursos de referência que você pode usar hoje
- Otimizar atraso de entrada
- Avaliação de script e tarefas longas
- Como tamanhos grandes de DOM afetam a interatividade e o que você pode fazer a respeito
- Renderização de HTML e interatividade do lado do cliente
- Otimizar a Mudança de layout cumulativa
- Crie experiências do WordPress no navegador com o WordPress Playground e o WebAssembly
- Cumulative Layout Shift (CLS)
- Nova funcionalidade para desenvolvedores oferecida pelo WebAssembly
- PWAs em app stores
- O que são os mapas de origem?
- 6 snippets de CSS que todos os desenvolvedores front-end precisam conhecer em 2023
- Funções trigonométricas no CSS
- Realizar operações eficientes por frame de vídeo em vídeo com requestVideoFrameCallback()
- Destaques da comunidade do GDE: Lars Knudsen
- Novos padrões para apps de música
- Dica rápida de CSS! Texto em gradiente animado
- Criando o Chrometober!
- Como criar um componente de dica
- Fazer login com uma chave de acesso usando o preenchimento automático de formulários
- Criar uma chave de acesso para logins sem senha
- Como criar um componente de botão de ação flutuante (FAB)
- Práticas recomendadas para fontes
- Dica rápida de CSS! Carregador animado
- Como testar o contraste de cores do design da Web
- Destaque da comunidade do GDE: Alba Silvente Fuentes
- Criar a navegação principal de um site
- É :modal?
- Estilo da lista de criativos
- Práticas recomendadas para tags e gerenciadores de tags
- Como criar uma ilusão de grade torta
- Como a Nordhealth usa propriedades personalizadas em Web Components
- Controle mais refinado sobre transformações CSS com propriedades de transformação individuais
- Animações de borda CSS
- Como a BBC está lançando o HSTS e melhorias na segurança e no desempenho.
- Por que os dados de laboratório e de campo podem ser diferentes e o que fazer a respeito
- Todos saem ganhando
- O fim do Internet Explorer
- Adeus ao HTML5Rocks
- Receitas de cookies primários
- Sincronizar reprodução de áudio e vídeo na Web
- Usar gradientes cônicos para criar uma borda fria
- Implementar o tratamento de erros ao usar a API Fetch
- Escolher uma biblioteca ou um framework JavaScript
- A diferença entre bibliotecas e frameworks JavaScript
- Guia do desenvolvedor de front-end para o terminal
- Uma API para fontes da Web bonitas e rápidas
- GOV.UK remove o jQuery do front-end.
- Como criar um componente de botão
- Não combater o scanner de pré-carregamento do navegador
- Minimizar a distância
- Práticas recomendadas para medir as Métricas da Web no campo
- Encontrar coragem e inspiração na comunidade de desenvolvedores
- Fontes variáveis na vida real
- Crie gradientes CSS rapidamente com o CSS Gradient Creator
- Análise detalhada dos principais pontos problemáticos do desenvolvedor da Web
- Melhore a imagem do seu site com images.tooling.report
- Escopo de variáveis globais e locais
- Como criar um componente de caixa de diálogo
- Depurar erros de reprodução de mídia na Web
- Destaque da comunidade do GDE: Nishu Goel
- Os efeitos de desempenho de muito carregamento lento
- Como criar um componente da barra de carregamento
- Salvar credenciais de formulários
- Chrome e Firefox em breve para alcançar a versão principal 100
- Como criar um favicon adaptável
- Desenho em tela em Emscripten
- Melhore a segurança e a privacidade atualizando o cache HTTP
- Elementos HTML adicionais
- Portabilidade de aplicativos USB para a Web. Parte 2: gPhoto2
- Registro de erros de rede (NEL, na sigla em inglês)
- Detecção de recursos do WebAssembly
- Portabilidade de aplicativos USB para a Web. Parte 1: libusb
- Como criar um componente de mudança de tema
- Como incorporar snippets de JavaScript em C++ com Emscripten
- PWAs no Oculus Quest 2
- Design de edifícios
- Calculadora Designcember
- Como fazer cópia profunda em JavaScript usando oStructuredClone
- Como criar um componente de aviso
- O fundo da interface
- Como criar um componente de menu de jogo 3D
- Em relação a uma métrica de suavidade da animação
- Tudo do anúncio na Conferência de Desenvolvedores Chrome 2021
- Fluxos de usuários do Lighthouse
- Novidades do PageSpeed Insights
- A jornada do Photoshop para a web
- Como criar um componente de seleção múltipla
- Como avaliar o desempenho de carregamento no campo com a Navigation Timing e a Resource Timing
- Manipulação segura do DOM com a API Sanitizer
- Práticas recomendadas para o uso de incorporações de terceiros
- Como as arquiteturas de SPA afetam as Principais métricas da Web
- Detalhamento do evento JavaScript
- Como agrupar recursos que não são JavaScript
- Como criar um componente de botão de divisão
- Como usar scripts de módulo CSS para importar folhas de estilo
- Como criar um componente de switch
- Cor de destaque do CSS
- Cabeçalhos de dicas do cliente de recursos de mídia de preferências do usuário
- Como criar um componente de navegação estrutural
- Como usar linhas de execução WebAssembly do C, C++ e Rust
- PWA com streaming off-line
- Noções básicas de streaming de mídia
- Criptografia de mídia
- Frameworks de mídia
- Ajuste de tamanho do CSS para @font-face
- Como criar um esquema de cores
- Como usar o AVIF para compactar imagens no site
- CSS para Métricas da Web
- Evolução da Mudança de layout cumulativa nas ferramentas da Web
- Novos seletores funcionais de pseudoclasse CSS :is() e :where()
- O novo treinamento do Progressive Web App já está disponível
- O novo responsivo: Web design em um mundo orientado a componentes
- Migrar para as dicas de cliente do user agent
- Referência rápida sobre cabeçalhos de segurança
- Excalidraw e Fugu: como melhorar as principais jornadas do usuário
- Módulos ES em service workers
- Como criar um componente de rolagem de mídia
- Como otimizar as Métricas da Web usando o Lighthouse
- Como usar APIs da Web assíncronas do WebAssembly
- Personalize a sobreposição dos controles de janela da barra de título do PWA
- Como manter scripts de terceiros sob controle
- Quebra de barreiras com a API DataTransfer
- Preencher formulários OTP em iframes de origem cruzada com a API WebOTP
- Como criar animações de texto dividido
- Evolução da métrica de CLS
- Satisfação do desenvolvedor da Web
- Como criar um componente de configurações
- Depurar mudanças de layout
- JavaScript: o que isso significa?
- Estrutura, ciclo de vida e pacotes do projeto
- Como programar o mini app
- Marcação, estilo, script e atualização de mini apps
- Projetos de código aberto de mini apps
- O que são H5 e QuickApp?
- Como aplicar os princípios de programação do miniapp a um projeto de exemplo
- Considerações finais sobre miniapps de um desenvolvedor da Web
- Componentes de mini app
- Streams: o guia definitivo
- Como criar um componente de guias
- Um guia para ativar o isolamento de origem cruzada
- Como solicitar o isolamento de desempenho com o cabeçalho Origin-Agent-Cluster
- A propriedade aspect-ratio do CSS
- WebRTC agora é um padrão W3C e IETF
- Práticas recomendadas para carrosséis
- Quando usar HTTPS para desenvolvimento local
- Feedback necessário: o caminho para uma melhor métrica de troca de layout para páginas de longa duração
- Usar HTTPS para desenvolvimento local
- Codelab: como criar um componente de navegação lateral
- Como criar um componente de navegação lateral
- Codelab: Centralização no CSS
- Centralização no CSS
- Amo seu cache ❤️
- Worklets de pintura entre navegadores e Houdini.how
- Práticas recomendadas para o formulário de pagamento e endereço
- Práticas recomendadas para formulários de OTP por SMS
- Codelab de práticas recomendadas para o formulário de endereço
- Práticas recomendadas para o formulário de inscrição
- Codelab de práticas recomendadas para formulários de pagamento
- Como automatizar auditorias com o AutoWebPerf
- Codelab de práticas recomendadas para formulários de inscrição
- Comunicação bidirecional com service workers
- Guia de armazenamento em cache imperativo
- Visão geral dos workers
- Transmitir atualizações para páginas com os service workers
- Desative a aceleração do mouse para melhorar a experiência de jogo com QPS
- Como criar um componente de histórias
- Codelab: como criar um componente de Histórias
- Carregamento lento no nível do navegador para CMSs
- Schemeful Same-Site
- Codelab: criar um servidor de notificações push
- Codelab: criar um cliente de notificação push
- Visão geral das notificações push
- Medir o uso off-line
- Exemplos de animações CSS de alto desempenho
- Trocas assinadas (SXGs)
- CSS min(), max() e clamp()
- Melhorias no layout lógico com atalhos relativos ao fluxo
- Por que algumas animações estão lentas?
- Como processar solicitações de intervalo em um service worker
- Como criar animações CSS de alto desempenho
- Controlar o movimento, a inclinação e o zoom da câmera
- O que são testes de origem de terceiros?
- Vazamentos de memória da janela removida
- Criar uma página substituta off-line
- Core Web Vitals
- Crie formas de imagens interessantes com a propriedade clip-path do CSS's
- Marcadores personalizados com CSS ::marker
- Ajude os usuários a mudar a senha com facilidade adicionando um URL conhecido para isso
- Como orquestrar transações de pagamento com um service worker
- Como lidar com informações de pagamento opcionais com um service worker
- ARIA: veneno ou antídoto?
- Como depurar vazamentos de memória no WebAssembly usando o Emscripten
- content-visibilidade: a nova propriedade de CSS que melhora o desempenho de renderização
- Desbloqueando o acesso à área de transferência
- Práticas recomendadas para referências e políticas de referenciadores
- Web no Android
- Como criar um PWA no Google, parte 1
- Monitoramento de desempenho com o Lighthouse CI
- Projetar a experiência do usuário com chaves de acesso nas Contas do Google
- @property: como atribuir superpoderes às variáveis CSS
- Como fornecer dados de contato e de envio de um app de pagamento para Android
- Armazenamento em cache de service worker e armazenamento em cache HTTP
- Como registrar um app de pagamento baseado na Web
- Visão geral dos apps de pagamento baseados na Web
- Relação da velocidade do site e das métricas de negócios
- Como processar solicitações de navegação
- Usar o Relatório de UX do Chrome para analisar o desempenho no campo
- Dez layouts modernos em uma linha de CSS
- Renderização perfeita com devicePixelContentBox
- Encerramento do web.dev AO VIVO
- Usar recursos de navegadores multiplataforma para criar um formulário de login
- Aprimorar progressivamente seu Progressive Web App
- Práticas recomendadas para formulários de login
- Ferramentas para desenvolvedores da Web para depurar problemas de JavaScript na Pesquisa Google
- Como criar experiências de pesquisa resilientes com o Workbox
- Adicionar mídia a uma página da Web
- Link em negrito onde ninguém havia vinculado antes: fragmentos de texto
- Deixe o PWA mais parecido com um app
- Como registrar um bom bug do navegador
- Medir o desempenho com o modelo RAIL
- Acelerar as navegações no React com o Quicklink
- Proteja seus recursos contra ataques na Web com a busca de metadados
- Reordenação de conteúdo
- Melhorias na API Web Animations no Chromium 84
- Como configurar uma forma de pagamento
- Capacitação de apps de pagamento com o Web Payments
- Ciclo de vida de uma transação de pagamento
- Guia para desenvolvedores de apps de pagamento do Android
- Mais opções de fontes variáveis para a fonte da IU do sistema macOS no Chromium 83
- Como os Progressive Web Apps podem impulsionar o sucesso dos negócios
- Realize tarefas rapidamente com os atalhos de apps
- Preparação para a remoção do AppCache
- Como definir sua estratégia de instalação
- Armazenamento persistente
- Como a CommonJS está aumentando seus pacotes
- Por que você precisa do "isolamento de origem cruzada" para recursos avançados
- Como criar perfis de apps de áudio da Web no Chrome
- Melhoria no desempenho do carregamento de páginas do Next.js e do Gatsby com agrupamento granular
- "Mesmo site" e "mesma origem"
- Monitorar o uso total da memória da sua página da Web com medidaUserAgentSpecificMemory()
- Como tornar seu site "isolado de origem cruzada" usando COOP e COEP
- Blog de engenharia web.dev no 1: como criamos o site e usamos componentes da Web
- Melhoria no estilo padrão do modo escuro com a propriedade CSS do esquema de cores e a metatag correspondente
- Confira se o site está disponível e pode ser usado por todas as pessoas durante a pandemia da COVID-19
- Design responsivo acessível
- Áreas de toque acessíveis
- Corrigir um servidor sobrecarregado
- Acessibilidade de cor e contraste
- Evite vulnerabilidades de scripting em vários locais baseado em DOM com os Tipos confiáveis
- Como usar um PWA no seu app Android
- Evite a mudança de layout e o flash de texto invisível (FOIT, na sigla em inglês) pré-carregando fontes opcionais
- Como configurar Signed HTTP Exchanges (SXG) usando nginx
- Como distribuir Signed HTTP Exchanges (SXG) usando nginx
- Otimizar imagens de plano de fundo CSS com consultas de mídia
- Correção da velocidade do site de modo multifuncional
- Ajuste de rolagem após mudanças de layout
- Como configurar trocas assinadas usando o Web Packager
- Como oferecer sua própria experiência de instalação no app
- Posicionar objetos virtuais em visualizações do mundo real
- Realidade aumentada: você talvez já saiba
- A realidade virtual chega à Web, parte II
- Como desenvolver o ecossistema de framework da Web
- O que são Progressive Web Apps?
- Integrar PWAs a IUs de compartilhamento integradas com o Workbox
- Compatibilidade com ícones adaptativos em PWAs com ícones mascaráveis
- Melhorias na dispensa de páginas em XMLHttpRequest() síncrono
- Como criar linhas de execução na Web com workers do módulo
- Carregamento adaptável: como melhorar o desempenho da Web em dispositivos lentos
- Evoluções das ferramentas de velocidade: destaques da Conferência de Desenvolvedores do Chrome 2019
- Use web workers para executar JavaScript fora da thread principal do navegador
- Feedback da pesquisa de otimização de imagens de 2019
- Criar um servidor de notificações push
- Pré-busca de rotas no Next.js
- Desempenho como padrão com o Next.js
- Integrar a IU de compartilhamento do SO usando a API Web Share
- Como o AMP pode garantir a rapidez no app Next.js
- Divisão de código com importações dinâmicas no Next.js
- A realidade virtual chega à Web
- Compreensão dos cookies
- Receitas de cookies SameSite
- Anúncios rápidos são importantes
- Usar notificações push para engajar e reengajar usuários
- Começar a usar a API Notifications
- Usar um service worker para gerenciar notificações
- Corrigir instabilidade de layout
- Técnicas para fazer um app da Web carregar rapidamente, mesmo em um feature phone
- Propriedades personalizadas mais inteligentes com a nova API da Houdini
- Buscar recursos para acelerar navegações futuras
- Duas formas de pré-busca: tags <link> e cabeçalhos HTTP
- O que é conteúdo misto?
- Corrigir conteúdo misto
- Vá além das imagens com vídeos básicos para a Web
- Adicionar um ícone de toque da Apple ao seu Progressive Web App
- Player pronto para a Web
- Progressive Web Apps em sites de várias origens
- Otimizar o carregamento e a renderização de WebFont
- Reduzir o tamanho da fonte na Web
- Criar um Progressive Web App com a CLI Angular
- Identificar JavaScript de terceiros lento
- Usar CDNs de imagens para otimizar imagens
- Carregar JavaScript de terceiros com eficiência
- Desempenho de JavaScript de terceiros
- Otimizar o JavaScript de terceiros
- Controles de formulário mais eficientes
- Estabeleça conexões de rede cedo para melhorar a velocidade percebida da página
- Crie planos de fundo no estilo do SO com filtro de pano de fundo
- Como manter tudo atualizado com o método desatualizado-while-revalidate
- Virtualizar listas grandes com o CDK do Angular
- Otimizar a detecção de alterações do Angular's
- Estratégias de pré-carregamento de rotas no Angular
- Adapte o vídeo à veiculação de imagens com base na qualidade da rede
- Navegação na Web mais rápida com pré-busca preditiva
- Auditar a acessibilidade do seu app Angular com o codelyzer
- Orçamentos de desempenho com a CLI Angular
- Pré-armazenamento em cache com o service worker do Angular
- prefere-color-scheme: Olá, escuridão, meu velho amigo
- Comece agora: otimizar um aplicativo do Angular
- Dicas importantes para a performance da Web
- Divisão de código no nível da rota no Angular
- Componentes da Web: o ingrediente secreto que ajuda a alimentar a Web
- Usar o Lighthouse para orçamentos de performance
- O valor da velocidade
- Atualizações nas APIs Web Payments
- Instalação da barra de endereço para Progressive Web Apps no computador
- Como a performance pode melhorar a conversão?
- Mentalidade de service worker
- Padrões para promover a instalação do PWA
- Como notifico os usuários de que meu PWA pode ser instalado?
- Políticas de imagem para carregamento rápido e muito mais
- Extrair CSS crítico
- As tarefas longas de JavaScript estão atrasando o tempo para interação da página?
- Extraia e insira CSS crítico inline com código
- Velocidade em escala: o que há de novo no desempenho na Web?
- Introdução ao PROXX
- Pesquisa visual com o Web Perception Toolkit
- Explicação sobre cookies SameSite
- Veiculação adaptável com base na qualidade da rede
- Experiência ativa com portais: navegação perfeita na Web
- Minifique e compacte payloads de rede com o brotli
- web.dev no I/O 2019
- Como permanecer rápido?
- O que é velocidade?
- Como medir a velocidade?
- Auditoria de acessibilidade com react-axe e eslint-plugin-jsx-a11y
- Adicionar um manifesto de app da Web com o app Create React
- Divisão de código com React.Lazy e Suspense
- Como começar: otimizar seu app React
- Virtualize listas grandes com uma janela de reação
- Pré-armazenamento em cache no app Create React com o Workbox
- Pré-renderizar rotas com o React-snap
- Codelab: pré-carregue recursos essenciais para melhorar a velocidade de carregamento
- prefere-redução-movimento: às vezes, menos movimento é mais
- Adiar CSS não essencial
- Confiança é boa, observação é melhor: Intersection Observer v2
- Fundamentos do Web design responsivo
- Folhas de estilo construíveis
- Renderização na Web
- Como usar o bundlesize com o Travis CI
- Incorporar orçamentos de performance no processo de criação
- Como definir orçamentos de desempenho com o webpack
- Como usar o bot do Lighthouse para definir um orçamento de performance
- Emscripten e npm
- Seu app está instalado? getinstaladoRelatedApps() vai avisar você!
- Exibir códigos modernos em navegadores modernos para acelerar o carregamento de página
- Como adaptar aos usuários com dicas do cliente
- Conceitos básicos do acesso ao teclado
- Títulos e pontos de referência
- Usar HTML semântico para facilitar o uso do teclado
- Semântica e leitores de tela
- Foco de estilo
- O que é acessibilidade?
- Rótulos e alternativas de texto
- Controlar o foco com o tabindex
- Tornar o app instalável
- Mesma política de origem e iframe
- Descubra oportunidades de performance com o Lighthouse
- Direção de arte
- Veicular imagens com dimensões corretas
- O que são ataques de segurança?
- Remover código não utilizado
- Substituir GIFs por vídeo
- Como medir a otimização de mecanismos de pesquisa com o Lighthouse
- Evitar solicitações de rede desnecessárias com o cache HTTP
- Veicular imagens com dimensões corretas
- Workbox: seu kit de ferramentas de service worker de alto nível
- Corrigir erros 404 não autorizados
- A segurança não deveria ser tão assustadora!
- Exibir imagens responsivas
- Sandbox do navegador
- Compartilhamento de recursos entre origens (CORS, na sigla em inglês)
- Substitua GIFs animados por vídeos para acelerar o carregamento da página