{"id":1559,"date":"2024-09-25T10:45:21","date_gmt":"2024-09-25T13:45:21","guid":{"rendered":"https:\/\/thiagorossi.com.br\/blog\/?p=1559"},"modified":"2025-11-26T16:44:03","modified_gmt":"2025-11-26T19:44:03","slug":"update-pwa","status":"publish","type":"post","link":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/","title":{"rendered":"Update PWA"},"content":{"rendered":"<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Update PWA<\/strong>: A natureza instal\u00e1vel de um PWA (Progressive Web App) exige uma estrat\u00e9gia clara para lidar com as atualiza\u00e7\u00f5es, garantindo que os usu\u00e1rios sempre recebam as funcionalidades e corre\u00e7\u00f5es mais recentes sem a necessidade de visitar uma loja de aplicativos.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">As atualiza\u00e7\u00f5es em um PWA se dividem em dois grupos principais: <strong>Atualiza\u00e7\u00e3o de Recursos Est\u00e1ticos (C\u00f3digo)<\/strong> e <strong>Atualiza\u00e7\u00e3o de Dados Din\u00e2micos<\/strong>.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">1. \ud83d\udcbe Atualiza\u00e7\u00e3o de Recursos Est\u00e1ticos (C\u00f3digo e Service Worker)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">A atualiza\u00e7\u00e3o do c\u00f3digo-fonte (HTML, CSS, JavaScript) \u00e9 controlada principalmente pelo <strong>Service Worker (SW)<\/strong> e requer t\u00e9cnicas de versionamento para for\u00e7ar o navegador a baixar os novos arquivos.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">A. Atualiza\u00e7\u00e3o do Service Worker<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">O navegador verifica se h\u00e1 uma nova vers\u00e3o do <code>service-worker.js<\/code> (a cada 24 horas ou na navega\u00e7\u00e3o). A atualiza\u00e7\u00e3o ocorre quando:<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li class=\"has-medium-font-size\">O conte\u00fado do arquivo (<code>service-worker.js<\/code>) \u00e9 <strong>diferente<\/strong> do arquivo que est\u00e1 ativo.<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Vers\u00e3o no URL (N\u00e3o recomendado, mas eficaz):<\/strong> Mudar o URL do registro for\u00e7a o navegador a baixar um novo arquivo.<\/li>\n<\/ol>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ A forma mais simples (mas n\u00e3o a ideal) de for\u00e7ar o navegador a buscar um novo arquivo\nif ('serviceWorker' in navigator) {\n  window.addEventListener('load', () =&gt; {\n    \/\/ Mudar o par\u00e2metro de query (?v=3) garante que um novo arquivo seja baixado\n    navigator.serviceWorker.register('\/service-worker.js?v=3'); \n  });\n}\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">B. Versionamento de Recursos (Hashing)<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Para garantir que novos assets (CSS\/JS) sejam carregados e armazenados no novo cache, voc\u00ea deve usar <strong>hashing<\/strong> no nome do arquivo.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Arquivo Antigo:<\/strong> <code>app.css<\/code><\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Novo Arquivo:<\/strong> <code>app.b3d5f8.css<\/code><\/li>\n<\/ul>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Isso \u00e9 feito automaticamente por ferramentas de <em>build<\/em> (como Webpack ou Workbox). O Service Worker na nova vers\u00e3o ir\u00e1 pr\u00e9-cachar o arquivo <code>app.b3d5f8.css<\/code> e deletar o cache do arquivo antigo durante o evento <code>activate<\/code>.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ Exemplo com Workbox, que automatiza o hashing e a l\u00f3gica do Service Worker:\n\/\/ O Workbox usa a 'revision' (o hash) para determinar se um arquivo precisa ser atualizado.\nworkbox.precaching.precacheAndRoute(&#91;\n  { url: '\/script.js', revision: 'hash-v1-2025' }, \n  { url: '\/style.css', revision: 'hash-v1-2025' } \n]);\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">2. \ud83d\udd03 Atualiza\u00e7\u00e3o de Dados Din\u00e2micos (API e Banco de Dados)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">A atualiza\u00e7\u00e3o de dados (informa\u00e7\u00f5es de usu\u00e1rios, feeds, listagens) exige estrat\u00e9gias de sincroniza\u00e7\u00e3o para garantir que o usu\u00e1rio veja o conte\u00fado mais recente.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">A. Polling (Busca Peri\u00f3dica)<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">A aplica\u00e7\u00e3o cliente faz requisi\u00e7\u00f5es (<code>fetch<\/code>) em intervalos regulares para verificar se h\u00e1 novos dados na API.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Vantagem:<\/strong> Simples de implementar.<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Desvantagem:<\/strong> Pode ser ineficiente e gerar tr\u00e1fego desnecess\u00e1rio se as atualiza\u00e7\u00f5es forem raras.<\/li>\n<\/ul>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">B. WebSockets (Tempo Real)<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Cria uma conex\u00e3o persistente e bidirecional com o servidor, permitindo que o servidor <strong>envie<\/strong> dados (push) para o cliente assim que eles estiverem dispon\u00edveis.<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Vantagem:<\/strong> Baixa lat\u00eancia, ideal para chat, placares e dados em tempo real.<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Desvantagem:<\/strong> Requer uma infraestrutura de servidor mais complexa.<\/li>\n<\/ul>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">C. Estrat\u00e9gias de Cache no <code>fetch<\/code><\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">O Service Worker pode ser configurado para usar a estrat\u00e9gia <strong>Network First, Cache Fallback<\/strong> para dados din\u00e2micos, garantindo que a vers\u00e3o mais recente da rede seja sempre buscada, mas com o cache como plano de fundo <em>offline<\/em>.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">3. \ud83d\udea8 Alertando o Usu\u00e1rio sobre a Nova Vers\u00e3o<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">O Service Worker atualizado pode estar ativo em segundo plano, mas os usu\u00e1rios podem estar usando uma vers\u00e3o antiga. \u00c9 importante notificar e incentiv\u00e1-los a <strong>recarregar<\/strong> a p\u00e1gina.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">O Evento <code>updatefound<\/code><\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">No lado do cliente (p\u00e1gina principal), voc\u00ea pode escutar o processo de registro para saber quando uma nova vers\u00e3o do SW foi baixada e est\u00e1 pronta para a ativa\u00e7\u00e3o.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\/\/ Frontend JavaScript\nnavigator.serviceWorker.register('\/service-worker.js')\n  .then((registration) =&gt; {\n    registration.onupdatefound = () =&gt; {\n      const installingWorker = registration.installing;\n\n      installingWorker.onstatechange = () =&gt; {\n        \/\/ Quando o estado muda para 'installed' (mas ainda n\u00e3o ativo)\n        if (installingWorker.state === 'installed') { \n          if (navigator.serviceWorker.controller) {\n            \/\/ Existe um SW antigo: uma nova vers\u00e3o est\u00e1 pronta!\n            showUpdateModal('Uma nova vers\u00e3o est\u00e1 dispon\u00edvel! Recarregue a p\u00e1gina.');\n          }\n        }\n      };\n    };\n  });\n<\/code><\/pre>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h3 class=\"wp-block-heading\">Notifica\u00e7\u00e3o ao Usu\u00e1rio<\/h3>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Ao detectar a nova vers\u00e3o, use elementos n\u00e3o-intrusivos (como um <strong>Snackbar<\/strong> ou um pequeno <strong>Modal<\/strong>) pedindo ao usu\u00e1rio que clique em um bot\u00e3o &#8220;Atualizar Agora&#8221; para for\u00e7ar o Service Worker a se ativar e a p\u00e1gina a recarregar.<\/p>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">4. \ud83d\uddc2\ufe0f Atualiza\u00e7\u00e3o de Metadados (Manifest)<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Atualizar o <code>manifest.json<\/code> (nome, \u00edcones, tema) geralmente \u00e9 simples:<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li class=\"has-medium-font-size\">Edite o arquivo <code>manifest.json<\/code>.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">O navegador verifica se h\u00e1 mudan\u00e7as no Manifest a cada navega\u00e7\u00e3o.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Quando mudan\u00e7as s\u00e3o detectadas, o novo Manifest \u00e9 baixado e as informa\u00e7\u00f5es de instala\u00e7\u00e3o s\u00e3o atualizadas no sistema operacional (\u00edcone, nome, etc.).<\/li>\n<\/ol>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Nota:<\/strong> N\u00e3o existe um campo <code>\"version\"<\/code> padr\u00e3o no Manifest. O versionamento de c\u00f3digo e cache \u00e9 sempre feito atrav\u00e9s do Service Worker e dos hashes de arquivo.<\/p>\n<\/blockquote>\n\n\n\n<div style=\"height:35px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\">\u2705 Conclus\u00e3o Update PWA<\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Update PWA: A estrat\u00e9gia de atualiza\u00e7\u00e3o de PWAs deve ser dupla: <strong>versionar os recursos est\u00e1ticos<\/strong> (usando <em>hashing<\/em> nos nomes de arquivo) para que o Service Worker possa baix\u00e1-los para um novo cache, e implementar uma l\u00f3gica eficiente (Polling, WebSockets ou estrat\u00e9gias de <code>fetch<\/code> espec\u00edficas) para <strong>sincronizar dados din\u00e2micos<\/strong>. <\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Al\u00e9m disso, a notifica\u00e7\u00e3o proativa do usu\u00e1rio, acionada pelo evento <code>updatefound<\/code> no Service Worker, \u00e9 essencial para garantir que a nova vers\u00e3o seja ativada e utilizada, oferecendo uma experi\u00eancia sempre atualizada e fluida.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Toda jornada tem um in\u00edcio, e o in\u00edcio para se tornar um desenvolvedor web \u00e9 dominar as seguintes tecnologias, que voc\u00ea encontra aqui mesmo:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/html\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp\" alt=\"HTML\" class=\"wp-image-600\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">HTML<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/css\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp\" alt=\"CSS\" class=\"wp-image-702\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">CSS<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/javascript\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp\" alt=\"Javascript\" class=\"wp-image-804\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">JavaScript<\/figcaption><\/figure>\n<\/div>\n<\/div>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">E se voc\u00ea gosta do nosso conte\u00fado, n\u00e3o deixe de contribuir adquirindo os servi\u00e7os e produtos dos nossos apoiadores e empresas que somos associados:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/hostinger.com.br\/?REFERRALCODE=1THIAGO62\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/03\/hostinger.png\" alt=\"Hospedagem Hostinger\" class=\"wp-image-92\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNDYlc\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/ofertas-amazon.webp\" alt=\"Ofertas Amazon\" class=\"wp-image-1308\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNKmt0\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/amazonprime.webp\" alt=\"Amazon Prime\" class=\"wp-image-1307\"\/><\/a><\/figure>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>Update PWA: A natureza instal\u00e1vel de um PWA (Progressive Web App) exige uma estrat\u00e9gia clara&#8230;<\/p>\n","protected":false},"author":1,"featured_media":1497,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-1559","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-pwa","wpcat-16-id"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.7 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Update PWA - BLOG THIAGO ROSSI<\/title>\n<meta name=\"description\" content=\"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Update PWA - BLOG THIAGO ROSSI\" \/>\n<meta property=\"og:description\" content=\"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..\" \/>\n<meta property=\"og:url\" content=\"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/\" \/>\n<meta property=\"og:site_name\" content=\"BLOG THIAGO ROSSI\" \/>\n<meta property=\"article:published_time\" content=\"2024-09-25T13:45:21+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-11-26T19:44:03+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"758\" \/>\n\t<meta property=\"og:image:height\" content=\"426\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"Thiago Rossi\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Thiago Rossi\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"6 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/\"},\"author\":{\"name\":\"Thiago Rossi\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\"},\"headline\":\"Update PWA\",\"datePublished\":\"2024-09-25T13:45:21+00:00\",\"dateModified\":\"2025-11-26T19:44:03+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/\"},\"wordCount\":783,\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"articleSection\":[\"PWA\"],\"inLanguage\":\"pt-BR\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/\",\"name\":\"Update PWA - BLOG THIAGO ROSSI\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"datePublished\":\"2024-09-25T13:45:21+00:00\",\"dateModified\":\"2025-11-26T19:44:03+00:00\",\"description\":\"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#primaryimage\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/08\\\/Capa-Artigos.webp\",\"width\":758,\"height\":426,\"caption\":\"PWA\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/update-pwa\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Update PWA\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"name\":\"THIAGO ROSSI\",\"description\":\"Mais de 20 anos de experi\u00eancia no mercado de TI!\",\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"alternateName\":\"TR | CURSO WEB DEV\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\",\"name\":\"THIAGO ROSSI\",\"alternateName\":\"TR | CURSO WEB DEV\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"width\":300,\"height\":300,\"caption\":\"THIAGO ROSSI\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"},\"sameAs\":[\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\",\"name\":\"Thiago Rossi\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"caption\":\"Thiago Rossi\"},\"description\":\"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \\\"GDD \u2013 O Guia Definitivo\\\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.\",\"sameAs\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\",\"https:\\\/\\\/instagram.com\\\/thiagorossix86\",\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"],\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/author\\\/thiagorossi\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Update PWA - BLOG THIAGO ROSSI","description":"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/","og_locale":"pt_BR","og_type":"article","og_title":"Update PWA - BLOG THIAGO ROSSI","og_description":"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..","og_url":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/","og_site_name":"BLOG THIAGO ROSSI","article_published_time":"2024-09-25T13:45:21+00:00","article_modified_time":"2025-11-26T19:44:03+00:00","og_image":[{"width":758,"height":426,"url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","type":"image\/webp"}],"author":"Thiago Rossi","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"Thiago Rossi","Est. tempo de leitura":"6 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#article","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/"},"author":{"name":"Thiago Rossi","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87"},"headline":"Update PWA","datePublished":"2024-09-25T13:45:21+00:00","dateModified":"2025-11-26T19:44:03+00:00","mainEntityOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/"},"wordCount":783,"publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","articleSection":["PWA"],"inLanguage":"pt-BR"},{"@type":"WebPage","@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/","url":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/","name":"Update PWA - BLOG THIAGO ROSSI","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#primaryimage"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","datePublished":"2024-09-25T13:45:21+00:00","dateModified":"2025-11-26T19:44:03+00:00","description":"Update PWA: Neste artigo, exploraremos as diferentes formas de atualizar PWAs, desde a atualiza\u00e7\u00e3o de dados e recursos at\u00e9 a notifica\u00e7\u00e3o do..","breadcrumb":{"@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/thiagorossi.com.br\/blog\/update-pwa\/"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#primaryimage","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/Capa-Artigos.webp","width":758,"height":426,"caption":"PWA"},{"@type":"BreadcrumbList","@id":"https:\/\/thiagorossi.com.br\/blog\/update-pwa\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/thiagorossi.com.br\/blog\/"},{"@type":"ListItem","position":2,"name":"Update PWA"}]},{"@type":"WebSite","@id":"https:\/\/thiagorossi.com.br\/blog\/#website","url":"https:\/\/thiagorossi.com.br\/blog\/","name":"THIAGO ROSSI","description":"Mais de 20 anos de experi\u00eancia no mercado de TI!","publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"alternateName":"TR | CURSO WEB DEV","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/thiagorossi.com.br\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Organization","@id":"https:\/\/thiagorossi.com.br\/blog\/#organization","name":"THIAGO ROSSI","alternateName":"TR | CURSO WEB DEV","url":"https:\/\/thiagorossi.com.br\/blog\/","logo":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","width":300,"height":300,"caption":"THIAGO ROSSI"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/linkedin.com\/in\/thiagox86"]},{"@type":"Person","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87","name":"Thiago Rossi","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","caption":"Thiago Rossi"},"description":"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \"GDD \u2013 O Guia Definitivo\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.","sameAs":["https:\/\/thiagorossi.com.br\/blog","https:\/\/instagram.com\/thiagorossix86","https:\/\/linkedin.com\/in\/thiagox86"],"url":"https:\/\/thiagorossi.com.br\/blog\/author\/thiagorossi\/"}]}},"_links":{"self":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1559","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/comments?post=1559"}],"version-history":[{"count":1,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1559\/revisions"}],"predecessor-version":[{"id":4999,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/1559\/revisions\/4999"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media\/1497"}],"wp:attachment":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media?parent=1559"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/categories?post=1559"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/tags?post=1559"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}