前言
現在不管是桌面客戶端還是移動客戶端,都會夾雜著一部分H5頁面,這種混合式的應用也是我們常說的Hybrid App。為什么會出現Hybrid App呢,早期是因為開發一個Android或iOS的客戶端,需要的人力成本比較大,開發周期比較長,后來有些團隊就通過將部分頁面拆分出來,由前端來完成,再通過在客戶端里的Webview來展示。
由于小編我半路轉行當程序猿,只對前端領域有所了解,對其他編程領域接觸較少,故不探討Webview的實現原理和與H5頁面交互的原理。有興趣的小伙伴自行百度搜索JSBridge的相關知識,或請教下客戶端(Windows、MacOS、Android、iOS)開發的同學,看看如何橋接JS與其他編程語言之間的聯系。
優缺點
凡事都是有好有壞,沒有絕對的解決方案。下面我總結下Hybrid App在開發過程中存在的優缺點,各位同學可自行判斷Hybrid App的好壞。
優點
缺點
通訊方式
以下代碼全部基于前端(React)進行演示,客戶端如何實現JS交互我就不多說了,可以找客戶端開發的同學了解下。通訊方式有如下兩種,都是使用JS代碼來完成,兼容性還是挺不錯的。
前端通知客戶端
在H5頁面里觸發鏈接跳轉,App Webview檢測到鏈接跳轉再進行攔截,因此可以通過URL上攜帶參數來告知App下一步應該做些什么。
import React, { Component } from "react";export default class App extends Component { componentDidMount() { location.href = "lsbox://toast?msg=頁面加載完畢"; // 通知App } render() { return ( <div className="app"> <button type="button" onClick={this.openMask.bind(this)}>點它</button> </app> ); } openMask() { location.href = "lsbox://mask?toggle=1"; // 通知App }}
以上執行了location.href = "lsbox://mask?toggle=1"來通知App打開遮罩層
如果同步觸發兩個或以上的location.href(下一個location.href接著上一個location.href),App可能只會接收到一個location.href發出的通知,所以需要對下一個location.href使用setTimeout設置通知時間間隔(可使用Async/Await封裝優化)
location.href = "lsbox://toast?msg=one";setTimeout(() => { location.href = "lsbox://toast?msg=two"; setTimeout(() => { location.href = "lsbox://toast?msg=three"; }, 100);}, 100);
客戶端通知前端
注入一些全局方法,App Webview直接操作全局方法來控制H5頁面,使用window.handleFunc = function() {}這樣的形式來定義注入的方法。
import React, { Component } from "react";export default class App extends Component { constructor(props) { super(props); this.state = { list: [0, 1, 2, 3, 4] }; } componentDidMount() { window.addNum = this.addNum.bind(this); // 暴露方法給App } render() { return ( <div className="app"> <ul>{this.state.list.map(v => <li key={v}>{v}</li>)}</ul> </div>; ); } addNum(num) { this.setState(prevState => ({ list: prevState.list.concat(num); })); }}
以上在組件加載完成后通過window.addNum = this.addNum.bind(this)將指定方法全局暴露到window上,App Webview可直接操作這些方法來控制H5頁面。
結語
寫到最后總結得差不多了,后續如果我想起還有哪些H5與App的通訊方式遺漏的,會繼續在這篇文章上補全,同時也希望各位朋友對文章里的要點進行補充或者提出自己的見解。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答