PWA
如何將網站當成原生App加至手機桌面
2019/04/15 11:22:51
1
6813
一. PWA簡介
PWA的全稱是Progressive Web App,翻譯過來就是漸進式增強的網頁應用。漸進式增強是PWA的開發宗旨,它的好處之一就是讓PWA能夠兼容所有的瀏覽器。利用Web的技術給移動端的設備提供App的體驗,這是PWA的目的。因此,PWA經過Google Chrome團隊的開發在可靠性、響應速度、用户體驗三方面,升級了原來Web App的體驗
。
二.讓系統會跳出是否將應用加至桌面的提示步驟
(1)在根路徑下創建manifest.json文件:
{
"name": "阿發",
"short_name": "阿發",
"theme_color": "#2196f3",
"background_color": "#2196f3",
"display": "standalone",
"Scope": "/",
"start_url": "/ChatWeb/chat",
"icons": [
{
"src": "resources/images/app/icon-144x144.png",
"sizes": "144x144",
"type": "image/png"
},
],
}
也可至https://app-manifest.firebaseapp.com/自動產生manifest.json文件
欄位簡介:
name | 應用程式名稱 |
short_name | 應用程式簡稱 |
theme_color | 主題顏色 |
background_color | 啟動畫面背景顏色 |
display | 顯示模式:fullscreen、standalone、minimal-ui、browser |
Scope | 相關設定影響範圍 |
start_url | 起始頁面 |
icons | 應用程式圖示(可設定多種size) |
(2)在根路徑下創建service-worker.js
self.addEventListener('install', function (event) {
});
self.addEventListener('activate', function (event) {
});
self.addEventListener('fetch', function (event) {
});
(3)網頁上加上 <link rel="manifest" href="
manifest
.json
"/>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title></title>
<link rel="manifest" href="manifest.json"/>
(4)初始化時執行下列script
1.註冊service-worker.js
2.監聽跳出提示後user的選擇
if('serviceWorker' in navigator){
navigator.serviceWorker
.register('service-worker.js')
.then(function(){
console.log('Service Worker 註冊成功');
}).catch(function(error) {
console.log('Service worker 註冊失敗:', error);
});
} else {
avalon.log('瀏覽器不支援 serviceWorker');
}
window.addEventListener('beforeinstallprompt', function(e) {
e.userChoice.then(function(choiceResult) {
if(choiceResult.outcome == 'dismissed') {
console.log('user取消安裝至桌面');
}
else {
console.log('user接受安裝至桌面');
}
});
});
(5)啟動應用時符合下列條件時系統會跳出是否將應用加至桌面的提示
1.必須為https協議
2.不能為無痕模式
3.還未安裝過該應用
4.必須為chrome android才支援
(6)目前IOS並無支援跳出是否將應用加至桌面的提示的功能,只能自行手動點擊分享圖標,再點擊添加到主屏幕,最後點擊確定即可
三.快速檢查功能是否OK
chrome上調成手機檢視模式後按下F12,然後選擇application,按下Add to homescreen後如果console沒有跳出錯誤提示即表示成功
四.成功效果