PWA是利用HTML、CSS、JavaScript构建的具备原生体验的渐进式网页应用,核心包括Service Worker实现离线与后台同步、Manifest提供安装感、现代API补足能力,并按浏览器能力分层增强。
PWA(Progressive Web App,渐进式网页应用)不是一种新语言或框架,而是利用现有Web技术(HTML、CSS、JavaScript)构建的一类具备原生应用体验的网站。它的核心目标是让网页在性能、可靠性、安装性和交互感上更接近原生App——不靠打包上架,而靠标准Web能力逐步增强。
Service Worker 是 PWA 的“大脑”,它是一段运行在浏览器后台的独立 JavaScript 脚本,不阻塞页面渲染,能拦截网络请求、缓存资源、管理推送通知。一旦注册并激活,即使用户断网,也能加载已缓存的页面或展示优雅降级内容。
S/CSS、图标)一个 JSON 格式的 manifest.json 文件告诉浏览器:这个网站可以被添加到主屏幕、该用什么图标和启动画面、以什么模式(全屏/独立窗口)打开。用户点击“添加到主屏幕”后,它就拥有了类似原生App的入口、启动动画和独立进程(无地址栏、无导航栏)。
PWA 并非完全复刻原生,而是按需调用 Web 平台日益成熟的接口,缩小体验差距:
PWA 的“Progressive”体现在它不强制要求所有功能同时生效。老浏览器只当普通网站用;支持 Service Worker 的浏览器自动获得离线能力;支持 Web App Manifest 的设备才显示“添加到主屏幕”提示;最新 Chrome 还支持 TWA(Trusted Web Activity)打包为 Android APK 上架商店。这种分层增强,让同一套代码在不同环境中保持可用且持续升级。
基本上就这些——没有黑科技,只有扎实用好浏览器给的能力。