漸進式Web應用(PWA)入門教程(上)

来源:https://www.cnblogs.com/powertoolsteam/archive/2018/05/18/ProgressiveWebApps_1.html
-Advertisement-
Play Games

最近關於漸進式Web應用有好多討論,有一些人還在質疑漸進式Web應用是否就是移動端未來。 但在這篇文章中我並不會將漸進式APP和原生的APP進行比較,但有一點是可以肯定的,這兩種APP的目標都是使用戶體驗變得更好。 移動端Web應用有很多優秀的概念讓人應接不暇,但好在編寫一個漸進式Web應用不是一個 ...


最近關於漸進式Web應用有好多討論,有一些人還在質疑漸進式Web應用是否就是移動端未來。

 

但在這篇文章中我並不會將漸進式APP和原生的APP進行比較,但有一點是可以肯定的,這兩種APP的目標都是使用戶體驗變得更好。

 

移動端Web應用有很多優秀的概念讓人應接不暇,但好在編寫一個漸進式Web應用不是一個很困難的事情。在這篇文章里將向你介紹如何把一個普通的網站轉換成漸進式Web應用。你可以按照這篇文章一步一步地做,做完之後你的網站將可以實現離線訪問,並且可以在桌面上創建該網站的圖標。那麼下麵即將開始入門教程。

什麼是漸進式Web應用?

漸進式Web應用是一種全新的Web技術,讓Web應用和原生APP的體驗相近或一致。

漸進式Web應用它可以橫跨Web技術及Native APP開發的解決方案,對於開發者的優勢如下:

  1. 你只需要關心W3C的Web標準,不用關心各種Native APP的代碼。
  2. 用戶可以在安裝應用之前先試用。
  3. 在漸進式Web應用中,你不需要使用各種應用商店來分發應用,也不用關心應用發佈時奇怪的審核標準以及應用內購的平臺抽成。另外,應用程式更新是自動進行的,無需用戶交互,所以整體的使用體驗對於用戶來講更為的平滑。
  4. 漸進式Web應用的“安裝”過程很快,只需要在主屏幕上添加一個圖標即可。
  5. 漸進式Web應用啟動時可以顯示一個好看的啟動畫面。
  6. 你可以在漸進式Web應用中提供具有全屏體驗的應用。
  7. 通過系統通知等形式提高用戶的粘性。
  8. 漸進式Web應用將會在本地緩存必要的文件,所以漸進式Web應用會比普通的Web應用的性能更好。

  9. 輕量級安裝——你只需要緩存幾百KB的數據即可。
  10. 所有的數據傳輸必須使用安全的HTTPS連接
  11. 漸進式Web應用可以離線緩存數據,並且會在重新連接互聯網時重新同步數據。

 

漸進式Web應用發展的現狀

漸進式Web應用才剛剛開始發展,但實際上在國內,有些網站已經實際開始PWA的實踐了,例如:微博、豆瓣、淘寶等平臺。可能這時候聰明的你可能就會產生疑問,那這個PWA不就是和微信小程式一樣嗎,對是這樣,二者的目的是一致的,就是在移動端為用戶提供足夠輕量且與原生應用使用體驗相近的“輕”應用。

 

但就目前來講,PWA是Google主推的一項技術標準,FireFox,Chrome以及一些基於Blink的瀏覽器已經支持漸進式Web應用了,Edge上對漸進式Web應用的支持還在開發。Apple公司也表示會考慮在自己Safari支持PWA。然而這項功能已經進入了WebKit內核的五年計劃中。長期來看,對瀏覽器相容性的支持方面應該已經不算太大問題了。況且在現階段,在不支持漸進式Web應用的瀏覽器中,你的應用也只是無法使用漸進式Web應用的離線功能而已,除此之外的功能均可以正常使用。

 

而在微信這邊,憑藉龐大的用戶基數和體量能否與PWA分庭抗禮乃至笑到最後目前還不得而知。

示例代碼

大多數教程都講述的是如何在Chrome上從零開始製作一個類似原生界面的應用。然而在這篇教程中,我們並不打算做一個單頁面應用程式,所以在這我們也不必瞭解諸如Material Design等知識。那麼下麵我們就直接看示例吧。

你可以從GitHub中獲取本教程對應的示例代碼。

 

本示例中提供了一個有四個網頁的網站,一個CSS文件和一個JavaScript文件。這個網站可以在所有的現代瀏覽器上正常工作(IE10+)。如果你的瀏覽器支持漸進式Web應用,用戶可以在離線狀態下將會直接訪問緩存中的頁面。

要想運行此示例,請確保你已經安裝了Node.js。並請打開命令行,使用以下命令來運行該示例:

node ./server.js [port]

 

以上命令中,[port]是可選部分,預設為8888。使用 Ctrl + C 即可停止Web伺服器。

 

打開基於Blink內核的瀏覽器(Opera,Vivaldi,Chrome),然後在地址欄中輸入http://localhost:8888/(註意埠號是否正確),即可訪問該示例。你可以打開開發者工具(F12 或者 Cmd/Ctrl + Shift + I)來查看控制台信息。

 

查看首頁,也可以在頁面上點擊一下,然後使用以下方法進入離線模式:

選中Network標簽或者Application -> Service Workers 標簽下的“離線”選項。重新訪問之前訪問過的網頁,之前網頁仍然會載入:

連接移動端安裝

除了在PC瀏覽器訪問外,你也可以在移動設備上訪問該示例。使用USB線纜將你的移動設備連接到電腦上,然後從右上角三個點菜單中打開More tools - Remote devices標簽

點擊左側的Settings菜單,然後添加一條埠映射(Port Forwarding)的規則,將8888映射為localhost:8888,現在你可以直接在手機打開Chrome然後訪問http://localhost:8888

你可以使用瀏覽器的“添加到主屏幕”功能將當前網頁添加到主屏幕,在你訪問了幾個頁面之後,瀏覽器會將這個Web應用“安裝”到你的設備上。瀏覽幾個頁面,關閉Chrome並將設備與電腦斷開連接,點擊桌面上生成的圖標,你會看到一個Splash頁面,並且你可以繼續瀏覽之前瀏覽過的頁面。

 

小結

通過本節對漸進式Web應用的介紹,相信大家對PWA是什麼已經有了基本的認識。PWA有無需擔心有無網路的特點,並具有獨立入口與獨立的保護機制。新標準的推出很可能會帶著 Web 應用在移動設備上浴火重生。所以滿足 PWA 模型的前端控制項,如純前端表格控制項SpreadJS,將逐漸成為移動操作系統的一等公民,並將向Native APP發起挑戰。

在下節中我們將帶你一起去看看,PWA的原理是什麼,以及它究竟是如何工作的,敬請期待。

原文鏈接:https://www.sitepoint.com/retrofit-your-website-as-a-progressive-web-app/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如何查看Windows伺服器安裝了那些SQL Server組件呢? 最近就遇到這樣一個需求,需要知道Windows伺服器是否安裝了Replication組件,那麼有幾種方法查看Windows伺服器安裝了哪些SQL Server組件呢?下麵總結一下這方面的方法,希望對遇到這樣問題的人有所幫助! 1:通... ...
  • 存儲過程太多,有時只記得存儲過程裡面的某一點類容,想要找到對應的存儲過程: SELECT obj.Name 存儲過程名, sc.TEXT 存儲過程內容 FROM syscomments sc INNER JOIN sysobjects obj ON sc.Id = obj.ID WHERE sc.T ...
  • Hadoop是一個開源的分散式系統框架 一.集群準備 1. 三台虛擬機,操作系統Centos7,三台主機名分別為k1,k2,k3,NAT模式 2.節點分佈 k1: NameNode DataNode ResourceManager NodeManager k2: SecondNameNode Dat ...
  • 下載並解壓 1. 從官方網站下載最新安裝包 2. 解壓到目標安裝目錄 新建配置文件 1. 在安裝目錄新建my.ini文件 2. 添加如下內容(需修改為自己的配置) 啟動服務 1. 使用命令行模式,跳轉到安裝目錄下的bin目錄 2. 執行安裝命令:mysqld install 3. 執行啟動命令:ne ...
  • 轉載:http://www.cnblogs.com/loveis715/p/5277051.html 最近我在用圖形資料庫來完成對一個初創項目的支持。在使用過程中覺得這種圖形資料庫實際上挺有意思的。因此在這裡給大家做一個簡單的介紹。 NoSQL資料庫相信大家都聽說過。它們常常可以用來處理傳統的關係型 ...
  • 一、知識介紹 1、ContentProvider是內容提供者 ContentResolver是內容解決者(對內容提供的數據進行操作) ContentObserver是內容觀察者(觀察內容提供者提供的數據變化) 2、ContentObserver需要ContentResolver進行註冊。 resol ...
  • 利用Android Studio創建完第一個Hello World項目後,我們會看到使用project模式的項目結構。 一、.gradle和.idea 這兩個目錄放置的是Android Studio自動生成的一些文件。 二、build 主要包含了一些在編譯時自動生成的一些文件。 三、gradle 包 ...
  • 一、Android系統版本簡介 Android操作系統已占據了手機操作系統的大半壁江山,截至本文寫作時,Android操作系統系統版本及其詳細信息,已發生了變化,具體信息見下表,當然也可以訪問https://developer.android.google.cn/about/dashboards/查 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...