【quickhybrid】組件(自定義)API的實現

来源:https://www.cnblogs.com/dailc/archive/2017/12/27/8124036.html
-Advertisement-
Play Games

前言 前文在API規劃時就已經有提到過組件API這個概念,本文將會介紹它的原理以及實現 理解組件API這個概念 在quick hybrid中,API是按模塊劃分的,如 ,`page 組件` 為什麼叫組件?可以這樣理解,模塊更多的是H5前端的叫法(因為在前端看來不同API分別屬於不同的模塊下), 而組 ...


前言

前文在API規劃時就已經有提到過組件API這個概念,本文將會介紹它的原理以及實現

理解組件API這個概念

quick.ui.xxx
quick.page.xxx

在quick hybrid中,API是按模塊劃分的,如uipage等都是不同模塊,而模塊的另一個名稱則是組件

為什麼叫組件?可以這樣理解,模塊更多的是H5前端的叫法(因為在前端看來不同API分別屬於不同的模塊下),
而組件則是原生那邊加強的理解概念(因為,每一個組件都是可以在項目中單獨存在的,譬如項目A中有組件pay,但項目B卻不一定集成有)

框架API和組件API

回到最初,quick hybrid的使命就是服務於N個項目,那麼會遇到一個問題-N個項目中可能會有非常多的需要以API方式提供的需求,但是考慮到體積以及通用性,並不是所有的都適合直接集成到框架中

此時,就需要對框架內容和項目內容進行區分,於是就有了框架API和組件API的概念(此時可以認為原生中框架文件是單獨打成一個靜態包給項目引用的,項目無法直接修改)

框架API

  • 直接打包到框架文件中(前端的quick.native.js,原生框架包中的API都會包含)

  • 使用的時候直接quick.xx模塊.xx功能即可調用(因為前端會將框架API都預設封裝)

  • config配置時無需單獨註冊(因為預設情況會註冊好)

  • 部分框架API會有H5下的實現(如部分系統級API都是有H5下的實現的)

組件API

  • 框架中不會包含,由各自的項目自行開發或集成(如某項目單獨集成一個個性化語音組件)

  • 使用的時候必須用quick.callAPi(...)並傳入合適參數(因為框架不會集成,需要通過這個萬金油方法調用)

  • config配置時必須註冊(需要傳入組件別名註冊,因為框架內部不知道這些新組件的)

  • 所有組件API都只是quick環境下的實現(一般都是一些原生中集成的拓展功能)

項目中如何拓展組件API

項目中預設只會打包框架API,但是框架的功能是有限的(只會集成一些最常用的功能),如果遇到一些個性化的需求(如支付,語音等等),則需要項目拓展組件API,總體步驟如下:

  • 1.原生引入框架,並實現對應的API介面,編寫API的功能代碼

  • 2.原生在項目配置文件中(不是框架配置文件)聲明對應的別名和路徑關係

  • 3.H5頁面初始化時,config,並傳入對應需要註冊的組件的別名

  • 4.容器接收到config方法後,去配置文件中根據別名找路徑,然後註冊對應路徑下的API類

  • 5.註冊成功後,H5頁面中通過callAPi來調用新註冊的組件API

原生實現API介面

原生中API的定義如下(以pay組件為示例)

Android中

public class PayApi implements IBridgeImpl {

     public static void payCustom(..., JSONObject param, final Callback callback) {
        // 做對應的支付工作,做完後回調
        ...
        callback.apply(...);
    }
}

iOS中

@implementation PayApi
- (void)registerHandlers {
    [self registerHandlerName:@"payCustom" handler:^(id data, WVJBResponseCallback responseCallback) {
        // 做對應的支付工作,做完後回調
        ...
        responseCallback(...);
    }];
}

聲明別名與路徑的關係

需要註意的是,Android和iOS中別名請保持一致,一般情況下鍵值對也可

譬如以示例項目為例,

Android在app模塊下的assets/modules.properties

pay = com.quick.quickhybrid.api.PayApi
...

同理iOS中也類似,只不過右側的路徑值可以換為iOS中的,如

pay = PayApi

可以看到,Android和iOS中的別名名稱相同,但是路徑不一致(因為各種的包機制不一樣)

H5中config註冊

H5中需要在config註冊拓展的組件,需要傳入別名(別名有對應的文檔說明-一般情況下同類型組件的別名是固定的)

quick.config({
   jsApiList: ['pay']
});

// error代表發生錯誤
quick.error(...);

// ready中是註冊成功
quick.ready(...);

原生容器註冊組件API

原生容器接收到config請求後就開始註冊組件,如下

// RegisterName: ui,page,pay之類的組件(模塊)名
// RegisterNclass: 對應的路徑,Android中和iOS中不一致

// RegisterNclass: 如com.quick.quickhybrid.api.PayApi
JSBridge.register(RegisterName, RegisterNclass);
// RegisterNclass: 如PayApi
[self registerHandlersWithClassName:@"RegisterNclass" moduleName:@"RegisterName"];

H5中調用組件API

註冊成功後,H5中通過特定方法調用

quick.callApi({
    name: 'testPay',
    mudule: 'pay',
    // 額外參數經常都需要
    data: {...},
    success: function(result) {
        quick.ui.toast(JSON.stringify(result));
    },
    error: function(error) {},
});

結束語

實際情況下,當項目足夠多時,拓展組件API是一種非常常見的場景,因此制定規範是很有必要的。

另外,一般情況下,很多相同功能的組件都是可以一起積累,多個項目復用的(比如支付,特定業務組件等等)

返回根目錄

源碼

github上這個框架的實現

quickhybrid/quickhybrid


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

-Advertisement-
Play Games
更多相關文章
  • [20171225]查看並行執行計劃註意的問題.txt--//如果使用dbms_xplan.display_cursor查看並行執行計劃註意一些問題,通過例子說明:1.環境:SCOTT@book> @ &r/ver1PORT_STRING VERSION BANNER x86_64/Linux 2. ...
  • MySQL事務 MySQL事務主要用於處理操作量大,複雜度高的數據。 比如說,在人員管理系統中,你刪除一個人員,你既需要刪除人員的基本資料,也要刪除和該人員相關的信息,如信箱,文章等等,這些資料庫操作語句就構成一個事務。 (1)在MySQL中只有使用了Innodb資料庫引擎的資料庫或表才支持事務。  ...
  • 概要 react native 環境搭建 hello react native react native 發佈 react native 優勢 1. 不用再學習 OC,Swift,Java,Kotlin 等 2. 復用 react 開發的種種好處 3. 開發體驗好(即時編譯) 4. 編譯出來的是原生 ...
  • 幾天前去物管交物業費,物管工作人員說小區引進高新產品,使用銀行卡消費後,不需要拿筆在銀聯機上簽名,直接用手指觸摸實現消費簽名,當時心想,果然是高科技,機子外形如下左圖,簽名如下右圖。 仔細一看,其實就是一個觸摸屏,用戶在上面直接手動簽名,實現這個功能其實並不複雜,我們自定義一個控制項,繼承view,使 ...
  • 解決方法: 修改這個文件 assets/data/dcloud_control.xml <msc version="1.9.9.39354" debug="true"><apps><app appid="yourapp" appver="1.0.3"/></apps></msc> 設置debug就可 ...
  • 在接入FaceBook第三方登錄的時候,需要獲取Android Hash Key。 Android Hash Key即密鑰散列有兩種,一種是開發秘鑰散列,一種是發佈秘鑰散列。這裡主要介紹如何獲取開發秘鑰散列Debug Android Hash Key。 步驟如下: 1、到https://code.g ...
  • 一.移動客服端實現對PC端數據的操作 在PC端模擬一個資料庫,實現用戶的增刪改查,然後在移動客服端實現對PC端資料庫的操作 在PC端建立三個表 用戶表(Users),員工表(Emp), 部門表(Dept), User表對應欄位,並設置對應的set/get方法,這裡不一一寫出 Emp表對應欄位 Dep ...
  • 參考自http://blog.csdn.net/u010752082/article/details/50810190 代碼先貼出來: 首先說明一下,要搜索到歌詞,需要先搜索歌曲,得到歌曲對應的id和accesskey後才能進行歌詞的獲取。 那麼我們先從搜索歌曲的URL開始說起: 其中的name為搜 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...