亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

Html5與App的通訊方式詳解

2024-09-05 07:23:05
字體:
來源:轉載
供稿:網友

前言

現在不管是桌面客戶端還是移動客戶端,都會夾雜著一部分H5頁面,這種混合式的應用也是我們常說的Hybrid App。為什么會出現Hybrid App呢,早期是因為開發一個Android或iOS的客戶端,需要的人力成本比較大,開發周期比較長,后來有些團隊就通過將部分頁面拆分出來,由前端來完成,再通過在客戶端里的Webview來展示。

由于小編我半路轉行當程序猿,只對前端領域有所了解,對其他編程領域接觸較少,故不探討Webview的實現原理和與H5頁面交互的原理。有興趣的小伙伴自行百度搜索JSBridge的相關知識,或請教下客戶端(Windows、MacOS、Android、iOS)開發的同學,看看如何橋接JS與其他編程語言之間的聯系。

優缺點

凡事都是有好有壞,沒有絕對的解決方案。下面我總結下Hybrid App在開發過程中存在的優缺點,各位同學可自行判斷Hybrid App的好壞。

優點

  • H5頁面交由前端進行開發,頁面模塊之間分開開發和維護,有效減少App的開發周期
  • H5頁面不受限于應用商店繁瑣的審核流程和冗長的等待時間,新增頁面和功能、修復缺陷都可隨時部署到線上
  • H5頁面在有需要時才加載,減小App打包后的大小,縮短App在應用商店下載的時間和減少本地占用手機的空間
  • H5頁面接入App Webview中,不再受限于瀏覽器,可通過與App交互調用設備更多底層的API來完善更多原本瀏覽器無法完成的操作

缺點

  • 協定好H5和App之間的通訊協議,定義好全局屬性和全局方法在兩者之間如何調用
  • H5頁面接入App Webview中,可能會出現很多兼容問題,需要前端和客戶端多加注意
  • 開發前需按照需求和交互進行頁面劃分,哪些頁面歸前端開發,哪些頁面歸客戶端開發
  • 頁面出現Bug有時候很難發現是在哪個環節出錯,需要前端和客戶端共同調試找出問題所在(可能各抒己見,打架都有份)

通訊方式

以下代碼全部基于前端(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打開遮罩層

  • lsbox:前端和客戶端統一定義鏈接跳轉的協議(喜歡怎樣定義協議都行)
  • mask:App需要執行的動作(喜歡怎樣定義動作都行)
  • 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的通訊方式遺漏的,會繼續在這篇文章上補全,同時也希望各位朋友對文章里的要點進行補充或者提出自己的見解。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91免费欧美精品| 国产精品久久一区主播| 91精品国产九九九久久久亚洲| 欧美性高跟鞋xxxxhd| 日韩欧美综合在线视频| 亚洲高清福利视频| 日本成人在线视频网址| 欧美日韩裸体免费视频| 国产亚洲欧美aaaa| 中文字幕av一区二区| 久久久999精品视频| 欧美激情亚洲激情| 欧美精品www| 国产小视频国产精品| 国产精品久久久久aaaa九色| 久久久在线观看| 亚洲欧美在线一区| 国产一区二区三区在线| 国产拍精品一二三| 久久久久成人精品| 欧美成人小视频| 精品国产1区2区| 国产精品久久久久久av| 久久琪琪电影院| 韩国福利视频一区| 日韩最新免费不卡| 一区二区日韩精品| 欧美性视频网站| 国产日韩精品入口| 欧美日韩亚洲网| 国产啪精品视频网站| 98午夜经典影视| 日韩av在线影视| 亚洲女成人图区| 欧美精品亚州精品| 日韩精品在线观看一区二区| 成人中文字幕在线观看| 亚洲精品按摩视频| 亚洲激情免费观看| 国产日韩欧美另类| 欧美性生交大片免费| 在线成人一区二区| www.美女亚洲精品| 国产精品露脸自拍| 国产经典一区二区| 国产高清在线不卡| 欧美华人在线视频| 97成人精品视频在线观看| 91系列在线观看| 成人中文字幕+乱码+中文字幕| 国产成人精彩在线视频九色| 亚洲自拍偷拍视频| 91亚洲精品久久久久久久久久久久| 日韩一区二区久久久| 欧美理论电影在线观看| 国产成人涩涩涩视频在线观看| 精品亚洲va在线va天堂资源站| 亚洲欧美日韩区| 日本国产一区二区三区| 亚洲香蕉av在线一区二区三区| 性欧美长视频免费观看不卡| 成人国产精品免费视频| 中文字幕欧美在线| 欧美裸体xxxx极品少妇| 成人在线精品视频| 久久激情五月丁香伊人| 国产成人在线一区二区| 热re91久久精品国99热蜜臀| 久久久国产精品x99av| 亚洲奶大毛多的老太婆| 欧美在线视频观看免费网站| 午夜精品视频在线| 久久久久久久久久久久av| 日本精品va在线观看| 久久亚洲电影天堂| 91精品久久久久久久久中文字幕| 亚洲天堂av在线播放| 久久99久久亚洲国产| 久久国产精品久久久久久久久久| 日韩精品免费综合视频在线播放| 91夜夜揉人人捏人人添红杏| 国产成人精品999| 国产成人精品在线观看| 色妞久久福利网| 日韩视频免费看| 一区国产精品视频| 超碰97人人做人人爱少妇| 国产va免费精品高清在线| 久久影院中文字幕| 欧美极品第一页| 欧美一级大片在线观看| 欧美激情videos| 久久免费视频这里只有精品| 成年人精品视频| 亚洲欧美国产精品| www.亚洲男人天堂| 亚洲风情亚aⅴ在线发布| 日韩美女视频在线观看| 国产亚洲视频在线观看| 久久深夜福利免费观看| 亚洲男女自偷自拍图片另类| 国产不卡精品视男人的天堂| 亚洲区中文字幕| 久久久在线免费观看| 国产精品一区二区av影院萌芽| 久久久久国产精品一区| 亚洲精品永久免费| 91精品免费视频| 日韩精品一区二区视频| 国产精品免费电影| 日日骚av一区| 91亚洲va在线va天堂va国| 国产欧美精品一区二区三区介绍| 91久久精品久久国产性色也91| 欧美一级黑人aaaaaaa做受| 久久久999国产精品| 日韩欧美综合在线视频| 欧美大片第1页| 欧美交受高潮1| 韩国19禁主播vip福利视频| 伊人久久大香线蕉av一区二区| 久99久在线视频| 精品香蕉在线观看视频一| 成人激情av在线| 国产精品久久久久久av福利| 亚洲欧美日本伦理| 日韩在线视频中文字幕| 欧美在线一级va免费观看| 成人免费自拍视频| 日韩精品久久久久久福利| 北条麻妃一区二区三区中文字幕| 黑人极品videos精品欧美裸| 日韩在线观看免费高清完整版| 97国产在线视频| 成人精品在线观看| 亚洲成人av片| 亚洲福利视频久久| 精品视频偷偷看在线观看| 欧美丰满少妇xxxxx做受| 亚洲日韩欧美视频一区| 国产亚洲精品久久久优势| 久久影院资源站| 国产91精品久久久久久| 欧美猛男性生活免费| 国产精品久久久久久中文字| 日韩经典中文字幕在线观看| 亚洲最大中文字幕| 国产一区二区在线免费| 国产精品网站入口| 久久夜色精品亚洲噜噜国产mv| 久久久久久亚洲| 久久久久99精品久久久久| 人妖精品videosex性欧美| 国产日韩欧美影视| 国产成人精品在线视频| 亚洲成人教育av| 在线观看视频99| 中文字幕久热精品在线视频| 伊人伊人伊人久久| 欧美日韩另类视频| 欧美孕妇孕交黑巨大网站| 国产网站欧美日韩免费精品在线观看| 日韩欧美一区二区三区| 97碰碰碰免费色视频|