网站添加pwa操作和配置manifest.json后,没有效果排查问题

pwa技术官网:https://web.dev/learn/pwa

应用清单manifest.json文件字段说明:https://web.dev/articles/add-manifest?hl=zh-cn

Web App Manifest:Web App Manifest | MDN

当网站添加了manifest.json文件后,也引入到html中了,但是打开网页却看不到效果,想要排查问题怎么排查呢?可以打开网页的检查,然后点击application:如果有问题,就可以看到报错的内容,然后针对内容想解决办法

如果没有问题的话,应该是没有错误和警告:

pwa事件:https://web.dev/learn/pwa/installation-prompt?hl=zh-cn 

创建清单文件

清单文件可以使用任何名称,但通常命名为 manifest.json,并从根目录(网站的顶级目录)提供。该规范建议该扩展程序应为 .webmanifest,但浏览器也支持 .json 扩展程序,这对开发者来说可能更容易理解。

典型的清单如下所示:

{"short_name": "Weather","name": "Weather: Do I need an umbrella?","icons": [{"src": "/images/icons-vector.svg","type": "image/svg+xml","sizes": "512x512"},{"src": "/images/icons-192.png","type": "image/png","sizes": "192x192"},{"src": "/images/icons-512.png","type": "image/png","sizes": "512x512"}],"id": "/?source=pwa","start_url": "/?source=pwa","background_color": "#3367D6","display": "standalone","scope": "/","theme_color": "#3367D6","shortcuts": [{"name": "How's weather today?","short_name": "Today","description": "View weather information for today","url": "/today?source=pwa","icons": [{ "src": "/images/today.png", "sizes": "192x192" }]},{"name": "How's weather tomorrow?","short_name": "Tomorrow","description": "View weather information for tomorrow","url": "/tomorrow?source=pwa","icons": [{ "src": "/images/tomorrow.png", "sizes": "192x192" }]}],"description": "Weather forecast information","screenshots": [{"src": "/images/screenshot1.png","type": "image/png","sizes": "540x720","form_factor": "narrow"},{"src": "/images/screenshot2.jpg","type": "image/jpg","sizes": "720x540","form_factor": "wide"}]
}

关键清单属性

short_name 和/或 name

您必须至少提供 short_name 或 name 属性。如果同时提供这两者,系统会在用户的主屏幕、启动器或空间可能有限的其他位置使用 short_name。在用户安装应用时使用 name

注意 :操作系统通常要求每个应用窗口都有一个标题。标题会显示在各种窗口切换界面(例如 Alt + Tab、概览模式和任务栏窗口列表)中。对于在独立模式下运行的 PWA,Chromium 会在 HTML 文档的 <title> 中指定的内容前面附加 short_name(如果未提供,则添加 name),以防伪装攻击,使独立应用可能被误认为是操作系统对话框。因此,当应用在独立模式下运行时,开发者不得在 <title> 中重复应用名称。

icons

当用户安装您的 PWA 时,您可以定义一组图标供浏览器在主屏幕、应用启动器、任务切换器、启动画面等位置使用。

icons 属性是图片对象的数组。每个对象都必须包含 srcsizes 属性和图片的 type。如需使用可遮盖图标(在 Android 中有时称为自适应图标),您还需要将 "purpose": "any maskable" 添加到 icon 属性。

对于 Chromium,您必须提供一个至少 192x192 像素的图标和一个 512x512 像素的图标。如果仅提供这两种图标大小,Chrome 会自动缩放图标以适应设备大小。如果您希望缩放自己的图标,并调整图标以实现像素完美,请以 48dp 为增量提供图标。

注意 :基于 Chromium 的浏览器还支持 SVG 图标,这些图标可任意缩放而不会像素化,并且支持对 prefers-color-scheme 的响应等高级功能,但需注意,这些图标不会实时更新,而是保持在安装时的状态。为了安全地使用 SVG 图标,对于不支持 SVG 图标的浏览器,您应始终指定光栅化图标作为后备选项。

id

借助 id 属性,您可以明确定义用于应用的标识符。向清单添加 id 属性会移除对 start_url 或清单位置的依赖,使其可在将来更新。有关详情,请参阅通过 Web 应用清单 ID 属性唯一标识 PWA。

start_url

start_url 是必需的,用于告知浏览器应用启动时应从何处启动,并阻止应用在用户将应用添加到主屏幕时所在的任何页面启动。

您的 start_url 应将用户直接定向到您的应用,而不是商品着陆页。想一想用户打开您的应用后会想要做什么,并将他们放在那里。

background_color

首次在移动设备上启动应用时,启动画面会使用 background_color 属性。

display

您可以自定义应用启动时显示的浏览器界面。例如,您可以隐藏地址栏和浏览器界面元素。游戏甚至可以 以全屏模式启动display 属性采用以下值之一:

属性使用情形
fullscreen打开没有任何浏览器界面的 Web 应用,并占据整个可用显示区域。
standalone打开 Web 应用,使其看起来和感觉像是一个独立应用。应用在其单独的窗口中运行,与浏览器分开,并隐藏网址栏等标准浏览器界面元素。
minimal-ui此模式与 standalone 类似,但只为用户提供了一组用于控制导航(例如返回和重新加载)的界面元素。
browser标准的浏览器体验。
display_override

如上文所述,Web 应用可以通过在其清单中设置 display 模式来选择其显示方式。浏览器需要支持所有显示模式,但需要支持规范定义的回退链 ("fullscreen" → "standalone" → "minimal-ui" → "browser")。如果它们不支持给定模式,则会回退到链中的下一个显示模式。在极少数情况下,这种不灵活的行为可能会带来问题。例如,在 "minimal-ui" 不受支持的情况下,开发者不得在未强制回到 "browser" 显示模式的情况下请求 "minimal-ui"。另一个问题是,当前行为导致无法以向后兼容的方式引入新的显示模式,因为标签页式应用模式等探索在回退链中没有自然位置。

这些问题可通过 display_override 属性解决,浏览器会在 display 属性之前考虑该属性。它的值是按列出顺序考虑的一系列字符串,并且会应用第一个支持的显示模式。如果两者都不受支持,浏览器会回退到评估 display 字段。

请参考以下示例。("window-control-overlay" 的详细信息不在本文的讨论范围内。)

{"display_override": ["window-control-overlay", "minimal-ui"],"display": "standalone",
}

如前所述,浏览器会先查看 display_override

  1. "window-control-overlay"
  2. "minimal-ui"

如果这两个选项都不可用,它会回退到 display。如果 "standalone" 不可用,它会从该时间点恢复规范定义的 Faabck 链。

  1. "standalone"
  2. "minimal-ui"
  3. "browser"

注意 :除非 display 也存在,否则浏览器不会考虑 display_override

scope

scope 定义了浏览器认为位于您应用中的一组网址,并用于确定用户何时离开应用。scope 可控制包含 Web 应用中的所有入口点和退出点的网址结构。您的 start_url 必须位于 scope 内。

注意 :如果用户在应用中点击了某个链接,但该链接会转到 scope 之外,则此链接会在现有 PWA 窗口中打开并呈现。如果您希望在浏览器标签页中打开该链接,则必须将 target="_blank" 添加到 <a> 标记中。在 Android 设备上,包含 target="_blank" 的链接会在 Chrome 自定义标签页中打开。

关于 scope 的一些其他说明:

  • 如果您未在清单中添加 scope,则默认的隐含 scope 是起始网址,但移除了其文件名、查询和片段。
  • scope 属性可以是相对路径 (../),也可以是任何有助于提高 Web 应用中的导航覆盖率的更高级别路径 (/)。
  • start_url 必须在范围内。
  • start_url 相对于 scope 属性中定义的路径。
  • 以 / 开头的 start_url 将始终是原点的根。
theme_color

theme_color 用于设置工具栏的颜色,并且可以反映在任务切换器中的应用预览中。theme_color 应与文档标头中指定的 meta 主题颜色一致。

采用自定义 theme_color 的 PWA 窗口示例。

从 Chromium 93 和 Safari 15 开始,您可以在媒体查询中使用 meta 主题颜色元素的 media 属性调整此颜色。系统会选择第一个匹配项。例如,您可以为浅色模式指定一种颜色,为深色模式指定另一种颜色。在编写时,您无法在清单中定义这些内容。请参阅 w3c/manifest#975 GitHub 问题。

<meta name="theme-color" media="(prefers-color-scheme: light)" content="white">
<meta name="theme-color" media="(prefers-color-scheme: dark)"  content="black">
shortcuts

shortcuts 属性是一组应用快捷方式对象,其目标是让用户快速访问应用内的关键任务。每个成员都是一个字典,至少包含一个 name 和一个 url

description

description 属性描述了应用的用途。

screenshots

screenshots 属性是一组图片对象,用于在常见使用场景中代表您的应用。每个对象都必须包含 srcsizes 属性和图片的 typeform_factor 属性是可选的。 您可以将它设置为 "wide"(对于仅适用于宽屏的屏幕截图)或 "narrow"(对于窄屏屏幕截图)。

在 Chrome 中,图片必须符合特定条件:

  • 宽度和高度必须介于 320 像素到 3840 像素之间。
  • 最大尺寸不能超过最小尺寸的 2.3 倍。
  • 与相应设备规格匹配的所有屏幕截图都必须具有相同的宽高比。
    • 从 Chrome 109 开始,桌面设备上只会显示 form_factor 设置为 "wide" 的屏幕截图。
  • 从 Chrome 109 开始,在 Android 设备上将忽略 form_factor 设置为 "wide" 的屏幕截图。为了向后兼容,系统仍会显示不含 form_factor 的屏幕截图。

桌面版 Chrome 至少会显示一张(最多八张)符合上述条件的屏幕截图。其余屏幕截图将会被忽略。

Android 版 Chrome 至少会显示一张且最多五张符合上述条件的屏幕截图。其余屏幕截图将会被忽略。

在桌面设备和移动设备上提供更丰富的安装界面。

创建清单后,将 <link> 标记添加到渐进式 Web 应用的所有页面。例如:

<link rel="manifest" href="/manifest.json">

针对清单发出的请求不使用凭据(即使请求位于同一网域中),因此,如果清单要求提供凭据,您必须在清单标记中添加 crossorigin="use-credentials"

测试清单

如需验证您的清单是否已正确设置,请使用 Chrome DevTools 的 Application 面板中的 Manifest 窗格。

在 Chrome 中,所有平台上的说明长度都不得超过 300 个字符。如果说明超过该限制,将会被截断并以省略号字符显示。在 Android 上,额外限制为最多 7 行。

在开发者工具中测试您的清单。

此窗格提供人类可读版本的许多清单属性,可让您轻松验证所有图片是否均已正确加载。

移动设备上的启动画面

当您的应用首次在移动设备上启动时,浏览器需要一些时间才能启动,然后才会开始呈现初始内容。浏览器会在进行首次渲染之前显示启动画面,而不是显示可能会像应用停滞一样向用户显示的白色屏幕。

Chrome 会根据清单属性自动创建启动画面,具体而言:

  • name
  • background_color
  • icons

background_color 应与加载页面的颜色相同,以便能够从启动画面平稳过渡到应用。

Chrome 将选择与设备的设备分辨率高度匹配的图标。在大多数情况下,提供 192 像素和 512 像素的图标就足够了,但您可以提供其他图标来使像素完美呈现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/267422.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

构建大语言模型的四个主要阶段

大规模语言模型的发展历程虽然只有短短不到五年的时间&#xff0c;但是发展速度相当惊人&#xff0c;国内外有超过百种大模型相继发布。中国人民大学赵鑫教授团队在文献按照时间线给出 2019 年至 2023 年比较有影响力并且模型参数量超过 100 亿的大规模语言模型。大规模语言模型…

66-ES6:var,let,const,函数的声明方式,函数参数,剩余函数,延展操作符,严格模式

1.JavaScript语言的执行流程 编译阶段&#xff1a;构建执行函数&#xff1b;执行阶段&#xff1a;代码依次执行 2.代码块&#xff1a;{ } 3.变量声明方式var 有声明提升&#xff0c;允许重复声明&#xff0c;声明函数级作用域 访问&#xff1a;声明后访问都是正常的&…

集成2.5G/5G/10G高速率网络变压器的RJ45网口连接器产品特点介绍

Hqst华轩盛(石门盈盛)电子导读&#xff1a;集成2.5G/5G/10G高速率网络变压器的RJ45网口连接器产品特点介绍&#xff1a; 第一、 高速率&#xff1a;支持高达2.5Gbps、5Gbps和10Gbps的传输速率&#xff0c;能够满足高带宽的网络应用需求。 第二、 集成2.5G/5G/10G高速率网…

【C++庖丁解牛】类与对象

&#x1f4d9; 作者简介 &#xff1a;RO-BERRY &#x1f4d7; 学习方向&#xff1a;致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f4d2; 日后方向 : 偏向于CPP开发以及大数据方向&#xff0c;欢迎各位关注&#xff0c;谢谢各位的支持 目录 1.面向过程和面向对象…

【5G 接口协议】GTP-U协议介绍

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

SQL注入漏洞解析--less-46

我们先看一下46关 他说让我们先输入一个数字作为sort,那我们就先输入数字看一下 当我们分别输入1&#xff0c;2&#xff0c;3可以看到按照字母顺序进行了排序&#xff0c;所以它便是一个使用了order by语句进行排序的查询的一种查询输出方式 当输入时出现报错提示&#xff0c;说…

STM32 | 零基础 STM32 第一天

零基础 STM32 第一天 一、认知STM32 1、STM32概念 STM32:意法半导体基于ARM公司的Cortex-M内核开发的32位的高性能、低功耗单片机。 ST:意法半导体 M:基于ARM公司的Cortex-M内核的高性能、低功耗单片机 32&#xff1a;32位单片机 2、STM32开发的产品 STM32开发的产品&a…

了解处理器

了解处理器 摘要写在前面1. 计算机简介1.1.计算机发展简史1.2.计算机分类1.3.PC机结构 2.初识处理器2.1.处理器的硬件模型2.2.处理器的编程模型2.3.处理器的分层模型2.4.如何选择处理器 3.指令集体系结构3.1.处理器编程模型3.2.指令集发展历程3.3.指令集分类3.4.汇编语言格式3.…

AI时代的产品文案秘籍:如何用AI提升效率

人工智能写作工具&#xff1a;解放双手&#xff0c;创作不停歇 在当前人工智能技术飞速发展的背景下&#xff0c;越来越多的个体已经开始利用这一AI写作工具&#xff0c;以显著提高自己的工作效率。这不仅标志着人工智能服务于人类的宏伟时代的到来&#xff0c;更是人人可用的创…

Unity RectTransform·屏幕坐标转换

RectTransform转屏幕坐标 分两种情况 Canvas渲染模式为Overlay时&#xff0c;使用此方式 public Rect GetScreenCoordinatesOfCorners(RectTransform rt) {var worldCorners new Vector3[4];rt.GetWorldCorners(worldCorners);var result new Rect(worldCorners[0].x,world…

前端导出word文件的多种方式、前端导出excel文件

文章目录 纯前借助word模板端导出word文件 &#xff08;推荐&#xff09;使用模板导出 前端通过模板字符串导出word文件前端导出 excel文件&#xff0c;node-xlsx导出文件&#xff0c;行列合并 纯前借助word模板端导出word文件 &#xff08;推荐&#xff09; 先看效果&#xf…

文件系统制作

文章目录 什么是文件系统如何制作根文件系统文件添加登录密码文件系统制作Squashfs制作方式gzip & lzo & xz 压缩 Jffs2制作方式 Ubi文件系统 什么是文件系统 Linux文件系统中的文件是数据的集合&#xff0c;文件系统不仅包含着文件中的数据而且还有文件系统的结构&am…

华硕ROG玩家国度幻16air 2024原装系统恢复安装教程方法

华硕ROG玩家国度幻16air 2024原装系统恢复安装教程方法 重建ASUSRECOVERY恢复功能 支持型号&#xff1a; GU605MI&#xff0c;GU605MY&#xff0c;GU605MZ GU605MV&#xff0c;GU605MU 分3种安装方法 远程恢复安装&#xff1a;https://pan.baidu.com/s/166gtt2okmMmuPUL1…

设计模式七:责任链模式

文章目录 1、责任链模式2、spring中的责任链模式Spring InterceptorServlet FilterNetty 1、责任链模式 责任链模式为请求创建了一个接收者对象的链&#xff0c;在这种模式下&#xff0c;通常每个节点都包含对另一个节点者的引用。每个节点针对请求&#xff0c;处理自己感兴趣…

【k8s相关资源api操作】

k8s相关资源api操作 文章目录 k8s相关资源api操作AdmissionregistrationApiextensionApiregistrationAppsV1ApiAutoscalingV1ApiBatchV1ApiCertificatesApi 证书相关CoordinationV1Api 最重要的CoreV1Api !!!CustomObjectsApiDiscoveryV1ApiEventsV1ApiFlowcontrolApiserverApi…

react-组件基础

1.目标 能够使用函数创建组件 能够使用class创建组件 能够给React元素绑定事件 能够使用state和setState() 能够处理事件中的this指向问题 能够使用受控组件方式处理表单 2.目录 React组件介绍 React组件的两种创建方式 React事件处理 有状态组件和无状态组件 组件中的state…

安卓14/aosp14相比安卓13录屏多了MirrorRoot深入剖析解密-千里马android framework实战开发

背景&#xff1a; 在马哥付费课群里技术讨论时候&#xff0c;有一个学员朋友提出一个问题&#xff0c;那就是录屏时候他提到了&#xff0c;aosp14会使用到一个Mirror对应图层的情况&#xff0c;针对录屏需要对录屏这个虚拟的display进行mirror原来的display。 可以用如下图来表…

C#入门:简单数据类型和强制类型转换

本文由 简悦 SimpRead 转码&#xff0c; 原文地址 mp.weixin.qq.com 本期来讲讲 unity 的脚本语言 —C#&#xff0c;C# 的简单数据类型及范围和强制类型转化的方法。这可是 unity 游戏开发必备技能。 1. 简单数据类型 各个类型的范围&#xff1a; byte -> System.Byte (字节…

手动实现一个简单的 HTTP 请求

本文我们通过 Socket&#xff0c;写一个 HTTP 协议&#xff0c;直观的感受一下上篇文章中的请求和响应。 定义 socket server 通过上篇文章&#xff0c;我们知道 HTTP 协议底层是通过 Socket 实现的&#xff0c;所以我们先通过 socket 定义一个 server import socket#初始化 …

Thread多线程(创建,方法,安全,通信,线程池,并发,并行,线程的生命周期)【全详解】

目录 1.多线程概述 2.多线程的创建 3.Thread的常用方法 4.线程安全 5.线程同步 6.线程通信 7.线程池 8.其它细节知识&#xff1a;并发、并行 9.其它细节知识&#xff1a;线程的生命周期 1.多线程概述 线程是什么&#xff1f; 线程(Thread)是一个程序内部的一条执行…