hybrid探索與實現

来源:https://www.cnblogs.com/88223100/archive/2023/05/29/Exploration-and-Implementation-of-Hybrid.html
-Advertisement-
Play Games

hybrid混合開發是一種離線移動應用開發方式,它結合了Web技術和原生技術,以網頁的形式嵌入到一個原生容器中。 ...


1.背景動機

1.1

hybrid是什麼

hybrid混合開發是一種離線移動應用開發方式,它結合了Web技術和原生技術,以網頁的形式嵌入到一個原生容器中。

 

1.2

為什麼選擇hybrid

1.實現更豐富的用戶體驗。hybrid app可以調用設備原生功能,如攝像頭、定位、藍牙等,提供更豐富的用戶體驗,這直接滿足了用戶使用app的需求。

2.更快速地獲取新功能。通過熱更新,用戶無需手動更新app就可以獲取最新的功能和內容,這大大提高了用戶使用體驗,用戶無需等待新版本發佈就可以使用新功能。

3.統一的交互界面。hybrid使用web技術開發界面,可以實現在iOS和Android平臺高度統一的界面和交互,這簡化了用戶的學習成本,用戶無需適應不同平臺下界面差異帶來的使用障礙。

4.更廣泛覆蓋用戶。一套hybrid代碼可以發佈到iOS和Android多個平臺,這覆蓋更廣泛的用戶群體,無論用戶使用什麼手機系統,都能使用該app,這提高了用戶使用可及性。

 

2.整體架構

圖片

在整體架構上主要涉及到了離線包管理平臺、app運行時邏輯,大致的思路:

1.h5工程打包完成的靜態資源通過離線包管理工具壓縮上傳至cdn和離線包管理平臺;
2.app通過介面獲取需要離線載入的資源包配置規則;
3.當h5命中需要離線的資源後,app會載入本地的靜態資源返回給網頁;

 

2.1

離線包管理系統

►2.1.1離線包管理平臺

1. 提供離線配置能力,app、h5接入控制與管理、應用離線能力開關;

2. 提供離線包版本管理,版本號、發佈時間查看、版本回退操作;

3. 離線包的發佈,app配置文件的更新,每次離線包發佈會同步更新對應客戶端配置文件;

 

►2.1.2離線包管理工具

1. 打包發佈腳本發佈到之家私有源,以腳手架命令形式調用,提供打包、上傳命令;

2. 業務方結合自身編譯上線流程進行調用,上傳完成則自動進行發佈;

3. 前端靜態資源按照頁面/工程緯度打包成zip;

4. zip包含js/css/img/pages/config.json配置文件;

 

腳本安裝:

// 腳本安裝
npm i @auto/dt-fe-cli
// 指定腳本的配置文件,打包並上傳至伺服器,預設配置文件為 config.json,可以使用 --config 指定配置文件
dt-fe-cli offline --config hybrid-config.json

資源包目錄

h5id
├── js/
├── css/
├── img/
├── pages
│   ├── index.html
│   └── list.html
└── config.json(配置文件) 

資源包配置文件:

  • h5Id-對應h5應用唯一標識

  • version-版本號

  • webpages-需要匹配替換的網頁列表

  • resources-需要匹配替換的靜態資源列表

  • web3d_t-需要匹配替換的3d資源

{
  "id": "432e53f06a",
  "h5Id": "432e53f06a",
  "version": "1.0.19",
  "webpages": [
    {
      "remoteUrl": "nets.xxx.com.cn/direction/68000",
      "path": "432e53f06a/1.0.19/direction/index.html",
      "contentType": "text/html"
    }
  ],
  "resources": [
    {
      "remoteUrl": "nets.xxx.com.cn/direction/css/2dScene.css",
      "path": "432e53f06a/1.0.19/direction/css/2dScene.css",
      "contentType": "text/css"
    },
    ...
  ],
  "appRules": {
    "ios": [
      "11.39.0",
      "infinite"
    ],
    "android": [
      "11.39.0",
      "infinite"
    ]
  },
  "web3d_t": [
    {
      "remoteUrl": "vrs3.xxx.cn/xxxx/vr_exhibition/q1VIB86H/Lsmt_FG01_ChaoPin",
      "downloadUrl": "https://vrs3.xxx.cn/xxxx/VR/MtHLNe/Lsmt_FG01_ChaoPin.zip",
      "path": "432e53f06a/1.0.19/Lsmt_FG01_ChaoPin"
    },
    ...
  ],
  "url": "http://nfiles3three.xxx.com.cn/mefcdn-xxxx/dt-fe-cli/offline/432e53f06a-1.0.19.zip"
}

 

 

►2.1.3發佈流程

1.在代碼打包編譯階段添加dt-fe-cli offline命令根據配置文件、靜態資源,生成資源包的資源映射配置,將靜態資源打包並上傳至後臺伺服器;

2.上傳至管理平臺的資源包會更新關聯測試環境應用的離線包配置信息,用於測試驗證;

3.測試驗證通過之後調用管理平臺發佈介面將驗證通過的離線包發佈至線上;

圖片

2.2

容器系統

圖片

►2.2.1webview管理

1.設置特定路由協議開啟容器;

2. 通過webclient攔截器攔截H5所有資源請求,匹配本地緩存邏輯:命中緩存時直接返回本地資源;未命中緩存則轉發給WebView進行預設處理;

3. 關閉Webview時檢查更新-監聽頁面關閉事件,關閉頁面時觸發預載入邏輯及離線包管理邏輯;

 

►2.2.2離線包管理

1. 檢查更新:調用預載入介面,結合離線包管理平臺邏輯,處理離線包更新;

2. 離線包下載:本地開啟多線程併發下載離線包,監聽下載結果,處理離線包解壓等流程;

3. 磁碟空間管理

(1)壓縮包解壓完成後刪除壓縮包;

(2)離線包更新後清理舊版本資源;

(3)設置離線包空間上限,結合LRU演算法進行離線包空間管理;

 

►2.2.3環境區分

1. 為了在測試階段快速判斷是否命中離線包資源;

2. 測試環境當html命中離線邏輯時,客戶端通過webview註入指定的js;

3. js在頁面插入浮動元素,標識當前頁面是否命中離線資源,標識區分2d/3d離線資源;

 

►2.2.4更新時機

1. 第一次冷啟動,app冷啟動20s後全量下載離線包;

2. 關閉webview後會更新資源;

3. 掃碼打開webview會立即下載當前url的離線資源包;

 

►2.2.5容災

當容器觸發以下情況時如果當前h5離線包存在會使用離線包資源,否則會使用線上資源;

1. 包解壓失敗;

2. 介面超時,離線包下載在網路狀態不好時,會有下載失敗的情況;

3. 下載離線資源失敗;

 

3.總結

目前這個方案已經在我們的項目中實際使用,實現了與業務的無縫融合,解決了頁面載入性能問題、白屏問題,大大提升了用戶的使用體驗。

 

作者|王卓 

本文來自博客園,作者:古道輕風,轉載請註明原文鏈接:https://www.cnblogs.com/88223100/p/Exploration-and-Implementation-of-Hybrid.html


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

-Advertisement-
Play Games
更多相關文章
  • 《公務員考試基礎知識題庫ACCESS資料庫》搜集了大量公務員考試試題,包括公共基礎知識試題、行政職業能力試題、法律基礎知識試題、公安基礎知識試題等。 分類記錄統計情況為:法律基礎知識試題(共1359條)、公安基礎知識試題(共1709條)、公共基礎知識試題(共2905條)、行政職業能力試題(共6613 ...
  • 《求職面試寶典大全ACCESS資料庫》包含:1-穿著打扮、2-隨身攜帶、3-場景指導、4-考官分析、5-考官問題、6-回答參考表、7-面試大全。雖然有些表的記錄數不多,但勝在信息全面以及考官問題及答案的全面。 問題類型記錄數為:待遇問題(10條)、個人素養(10條)、教育家庭(10條)、經驗問題(1 ...
  • 因為簽於網站笑話不是採用微博型(一句或兩句短篇可以採用250長度的文本型存儲),而是所以文章內容型,所以內容保存的欄位是 Microsoft Access 資料庫里的備註類型。 資料庫內容經過整理,格式比較統一,比如不會有多餘的段落或不整齊的段落;分類比較集中,只有爆笑男女(305)、兒童笑話(59 ...
  • [TOC](快速上手kettle二 小試牛刀) ### 一 、前言 上一期中大概介紹了下kettle,並已經把kettle下載安裝完了。 這一期我們就來簡單體驗下kettle怎麼進行數據轉換的。 ### 二 、兩個小目標 我們這裡呢就以兩個小案例來體驗下kettle - 將csv文件通過kettle ...
  • 這是從互聯網上搜集的各種初中語文作文20000篇,經過完美的格式內容整理,包含大量《中考滿分作文》及《中考作文指導》資料,資料庫按年級和分類可以快速的為初中作文提供最齊全的參考。 年級包含:初中二年級(2377)、初中三年級(1988)、初中一年級(15465)。分類包含:讀後感(778)、話題(1 ...
  • app界面逐漸複雜時,我們不得不考慮去優化界面性能。本文中介紹的例子在開發中是很常見的,如果不瞭解MediaQuery.of的機制,可能會引起大量使用此方法的界面發生重繪操作,造成頁面卡頓、幀率下降。我們詳細分析了背後的源碼邏輯,介紹瞭解決辦法,希望能給大家的調優工作提供些許幫助。 ...
  • “青春如同奔流的江河,一去不回來不及道別”,老男孩這首歌戳中了太多職場中年男人的心酸苦楚,面對經濟下行壓力、互聯網行業變革以及中年職場危機,互聯網人應該如何應對?如何建立和現實叫板的能力? 有2位在互聯網創業多年的開發者,經歷了從PC互聯網到移動互聯網的發展變遷,踩過不少坑,一路磕磕碰碰走到現在,放 ...
  • 中文版的笑話似乎日益更新,從來不缺少,但是英文版的似乎因為在中國的受眾少從而缺少這方面的展示,而今天獲得的就是近2萬的英文笑話內容,將將之存放到由Microsoft Office Access 2003 創建的資料庫中。截圖下方有顯示“共有記錄數”,截圖包含了表的所有欄位列。該數據提供ACCESS數 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...