PWA 介绍

概念:

PWA(Progressive web apps,渐进式 Web 应用)运用现代 Web API 和传统的渐进式增强策略来创建跨平台 Web 应用程序

它并不是一个快捷方式,而能在系统中作为一个独立的 App 存在,用户可设置它的权限,清除它的缓存

PWA 的关键技术在浏览器中的支持度:

1、Web App Manifest 的支持度达到 80.63%

2、Service Worker 的支持度达到 89.84%

3、Notifications API 的支持度达到 75.17%

4、Push API 的支持度达到 78.06%

产生原因:

1、Web 的用户体验:无论怎么优化,还是比 Native App 要差很多,始终无法突破移动设备上 WebView 给 Web 的枷锁

2、用户留存:Native App 安装后会在用户手机桌面上有一个入口,让用户打开 App 只需一次点击,而 Web App 在移动

时代最主要的入口还是搜索引擎;Native App 还能发送通知让用户再次回到应用中,而 Web 没有这个能力

3、Device API 的不完善:Android 和 iOS 提供了非常丰富的设备 API,Native App 只需获取用户授权就可以使用,

而在 Web App 中,WebView 没有提供这样的 API

主要特点:

1、可靠:即使在网络不稳定甚至断网的环境下,也能瞬间加载并展现

2、用户体验:快速响应,具有平滑的过渡动画及用户操作的反馈

3、用户黏性:和 Native App 一样,可以被添加到桌面,能接受离线通知,具有沉浸式的用户体验

主要特性:

1、渐进式:适用于所有浏览器,因为它是以渐进式增强作为宗旨开发的

2、连接无关性:能够借助 Service Worker 在离线或者网络较差的情况下正常访问

3、类原生应用:由于是在 App Shell 模型基础上开发,因此应具有 Native App 的交互,给用户 Native App 的体验

4、持续更新:始终是最新的,无版本和更新问题

5、安全:通过 HTTPS 协议提供服务,防止窥探,确保内容不被篡改

6、可索引:manifest 文件和 Service Worker 可以让搜索引擎索引到,从而将其识别为『应用』

7、黏性:通过推送离线通知等,可以让用户回流

8、可安装:用户可以添加常用的 Web App 到桌面,免去到应用商店下载的麻烦

9、可链接:通过链接即可分享内容,无需下载安装

最低要求:

1、站点需要使用 HTTPS

2、页面需要响应式,能够在平板和移动设备上都具有良好的浏览体验

3、所有的 URL 在断网的情况下有内容展现,不会展现浏览器默认页面

4、需要支持 Wep App Manifest,能被添加到桌面

5、即使在 3G 网络下,页面加载要快,可交互时间要短

6、在主流浏览器下都能正常展现

7、动画要流畅,有用户操作反馈

8、每个页面都有独立的 URL

传统 Web App,Native App 和 PWA 在各特性的对比

核心技术:

1、Web App Manifest:

(1)开发者可以定义用户添加到主屏的图标、应用名称等

(2)允许开发者配置隐藏浏览器多余的 UI(地址栏,导航栏等),让 PWA 具有和 Native App 一样的沉浸式体验

(3)体现在代码上主要是一个 JSON 文件:manifest.json,开发者可以在这个 JSON 文件中配置 PWA 的相关信息

2、Service Worker:在 PWA 中最重要的功能就是离线与缓存

(1)一个特殊的 worker 线程,独立于当前网页主线程,有自己的执行上下文

(2)一旦被安装,就永远存在,除非显示取消注册

(3)使用到的时候浏览器会自动唤醒,不用的时候自动休眠

(4)可拦截并代理请求和处理返回,可以操作本地缓存,如 CacheStorage,IndexedDB 等

(5)离线内容开发者可控

(6)能接受服务器推送的离线消息

(7)异步实现,内部接口异步化基本是通过 Promise 实现

(8)不能直接操作 DOM

(9)必须在 HTTPS 环境下才能工作

3、离线通知:

(1)离线通知是指在用户没有打开 PWA 站点的情况下,也能接受到服务器推送过来的通知并展现给用户

(2)包括了两部分,离线推送和展现通知,分别是 Web PushNotification API

(3)浏览器在接受到对应的消息服务中心推送过来的离线消息时,会唤醒对应站点注册的 Service Worker

开发者可以在 Service Worker 文件中处理接受到的请求,显示通知

4、App Shell 和骨架屏:

(1)App Shell 是 PWA 强调的一个非常重要的设计理念,它能够缩短用户进入页面时的白屏时间,

让用户一进入 PWA 就能快速看到 PWA 的整体框架

(2)骨架屏(App Skeleton),也是提升首屏体验的有效方式。原理是在真实内容渲染完成前,使用一些能够快速渲染的

静态图片/样式/色块/部分真实内容进行占位,让用户对真实内容区域有心理预期

(3)App Shell 和骨架屏相辅相成,App Shell 显示页面的外框部分,初始内容由骨架屏来填充,保证主体内容区域不留白

(4)特点:

·在页面加载初期预先渲染内容,提升感官上的体验

·一般情况骨架屏和实际内容的结构是类似的,因此之后的切换不会过于突兀

·只需要简单的 CSS 支持 (涉及图片懒加载可能还需要 JS ),不要求 HTTPS 协议,没有额外的学习和维护成本

·若页面采用组件化开发,每个组件可根据自身状态定义自身的骨架屏及其切换时机,同时维持了组件之间的独立性

PWA 学习笔记(一)的更多相关文章

  1. PWA 学习笔记

    深入学习网址:https://developer.mozilla.org/zh-CN/docs/Web/Progressive_web_apps 一. 基本介绍 1. 渐进式:适用所有浏览器,因为它是 ...

  2. pwa学习笔记--简介

    1. 介绍 Progressive Web App , (渐进式增强 WEB 应用) 简称 PWA ,是提升WebApp的体验的一种新方法,能给用户原生应用的体验. PWA 本质上是 Web App ...

  3. PWA 学习笔记(四)

    Service Worker 简介: 1.Service Worker 是 PWA 技术基础之一,脱离浏览器主线程的特性,使得 Web App 离线缓存成为可能, 更为后台同步.通知推送等功能提供了思 ...

  4. PWA 学习笔记(五)

    离线与缓存 资源请求的拦截代理: 1.资源请求的判断: (1)fetch 事件会拦截页面上所有的网络资源请求,但我们通常只对部分资源请求进行处理, 其余的请求会继续走浏览器默认的资源请求流程 (2)f ...

  5. PWA 学习笔记(三)

    基础技术简介 Promise: 1.ES6 引入的一种异步编程的解决方案,通过 Promise 对象来提供统一的异步状态管理方法 2.一般在使用 Promise 对象的时候,首先需要对其进行实例化 3 ...

  6. PWA学习笔记(二)

    设计与体验 APP Shell: 1.应用从显示内容上可粗略划分为内容部分和外壳部分,App Shell 就是外壳部分,即页面的基本结构 2.它不仅包括用户能看到的页面框架部分,还包括用户看不到的代码 ...

  7. Vue学习笔记-Vue.js-2.X 学习(四)===>脚手架Vue-CLI(基本工作和创建)

    (五) 脚手架Vue-CLI 一 Vue-CLI前提(nodejs和webpack) 二  Vue学习-nodejs按装配置,Node.js 就是运行在服务端的 JavaScript. 1. 去nod ...

  8. 爱了!阿里大神最佳总结“Flutter进阶学习笔记”,理论与实战

    前言 "小步快跑.快速迭代"的开发大环境下,"一套代码.多端运行"是很多开发团队的梦想,美团也一样.他们做了很多跨平台开发框架的尝试:React Native. ...

  9. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

随机推荐

  1. go学习第三天、数据类型

    基本数据类型 bool string int int8 int16 int32 int64 uint uint8 uint16 uint32 uint64 uintptr byte // alias ...

  2. HDU1944 S-NIM(多个NIM博弈)

    Arthur and his sister Caroll have been playing a game called Nim for some time now. Nim is played as ...

  3. BZOJ1014 火星人的prefix

    火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam,我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 7 8 9 10 11 字 ...

  4. ARTS-S mac终端ftp命令行上传下载文件

    上传 ftp -u ftp://root:123456@10.11.12.3/a.txt a.txt 下载 ftp -o a.txt ftp://root:123456@10.11.12.13/a.t ...

  5. [ Coding七十二绝技 ] 如何利用Java异常快速分析源码

    前言 异常一个神奇的东西,让广大程序员对它人又爱又恨.爱它,通过它能快速定位错误,经过层层磨难能学到很多逼坑大法.恨他,快下班的时刻,周末的早晨,它踏着七彩云毫无征兆的来了. 今天,要聊的是它的一项神 ...

  6. html小工具——文章注释编辑器

    在网上阅读文章时,读者时常会想针对某段文字写一些自己的感想,可惜大部分阅读网站并不提供这样的功能,读者往往只能将文本复制到本地或在线的编辑器中编辑注释,之后如果想在其他地方回顾这些注释也必须先本地安装 ...

  7. iOS开发 为何 大不如前?原因竟然是这个?

    前言: 近期,社会上对iOS开发行业的负面信息越来越多,并且还被一些黑骗机构的胡诌八扯越描越黑,现在iOS开发按照开发者与公司招聘的数量上来看,是显示的供大于求,但是从各公司的招人计划上来看,明显是供 ...

  8. swoole运行模式加速laravel应用的详细介绍

    本篇文章给大家带来的内容是关于swoole运行模式加速laravel应用的详细介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 一.Swoole Swoole号称重新定义了PHP, ...

  9. 用Python抢到回家的车票,so easy!

    “ 盼望着,盼望着,春节的脚步近了,然而,每年到这个时候,最难的,莫过于一张回家的火车票. ​ 据悉,今年春运期间,全国铁路发送旅客人次同比将增长 8.0%.达到 4.4 亿人次. ​ 2020 年铁 ...

  10. 一些实用的 Laravel 小技巧

    Laravel 中一些常用的小技巧,说不定你就用上了. 1.侧栏 网站一般都有侧栏,用来显示分类,标签,热门文章,热门评论啥的,但是这些侧栏都是相对独立的模块,如果在每一个引入侧栏的视图中都单独导入与 ...