婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Html5與App的通訊方式詳解

Html5與App的通訊方式詳解

熱門標簽:惡搞電話機器人 欣鼎電銷機器人 效果 高德地圖標注商戶怎么標 ok電銷機器人 智能電銷機器人被禁用了么 如何查看地圖標注 地圖標注軟件打印出來 電話機器人技術 黃石ai電銷機器人呼叫中心

前言

現在不管是桌面客戶端還是移動客戶端,都會夾雜著一部分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的通訊方式遺漏的,會繼續在這篇文章上補全,同時也希望各位朋友對文章里的要點進行補充或者提出自己的見解。

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

標簽:盤錦 萍鄉 中山 金昌 聊城 阿壩 赤峰 綏化

巨人網絡通訊聲明:本文標題《Html5與App的通訊方式詳解》,本文關鍵詞  Html5,與,App,的,通訊,方式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Html5與App的通訊方式詳解》相關的同類信息!
  • 本頁收集關于Html5與App的通訊方式詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    极品尤物av久久免费看| 亚洲影视在线观看| 日韩午夜在线影院| 欧美午夜精品理论片a级按摩| 国产不卡在线一区| 国产成人av电影在线播放| 国产精品69久久久久水密桃| 国产又粗又猛又爽又黄91精品| 久久99国产精品久久99| 狠狠色2019综合网| 成人精品视频网站| 99精品国产99久久久久久白柏| 国产v综合v亚洲欧| 不卡一区二区中文字幕| 日本韩国精品在线| 欧美精品在线观看一区二区| 日韩一区二区三区免费看| 欧美大片拔萝卜| 国产婷婷一区二区| 综合色中文字幕| 亚洲观看高清完整版在线观看| 日韩高清在线电影| 国产精品一区二区91| www.日韩在线| 日韩一区二区视频| 国产精品久久夜| 亚洲午夜影视影院在线观看| 精品一区二区三区免费| 成人激情电影免费在线观看| 欧美日韩国产首页| 久久夜色精品国产欧美乱极品| 国产喂奶挤奶一区二区三区| 亚洲一区二区三区爽爽爽爽爽| 看国产成人h片视频| 成人高清视频在线观看| 欧美日韩亚洲综合| 欧美经典一区二区| 午夜a成v人精品| 成人黄色av网站在线| 91精品国产一区二区三区蜜臀| 中文字幕免费不卡| 免费观看在线色综合| 99视频精品免费视频| 日韩免费高清av| 亚洲柠檬福利资源导航| 国内成+人亚洲+欧美+综合在线 | 亚洲精品在线免费观看视频| 中文av一区特黄| 青青草97国产精品免费观看无弹窗版| 国产成人午夜高潮毛片| 欧美一级艳片视频免费观看| 中文字幕制服丝袜一区二区三区| 亚洲二区视频在线| 成人开心网精品视频| 精品成人私密视频| 久久国产精品露脸对白| 欧美色图片你懂的| 亚洲影院免费观看| 在线观看精品一区| 一区二区久久久| 99久久久国产精品| 中文字幕欧美一| 成人黄色在线视频| 欧美激情一区二区三区四区| 国产综合色视频| www一区二区| 国产在线精品一区在线观看麻豆| 日韩欧美激情一区| 日本特黄久久久高潮| 在线不卡免费av| 午夜精品123| 欧美精品第1页| 无吗不卡中文字幕| 欧美一区二区三区视频| 日韩av二区在线播放| 日韩无一区二区| 免费高清视频精品| 精品国产伦一区二区三区免费| 美女在线一区二区| 精品国产sm最大网站免费看 | 国产区在线观看成人精品| 奇米精品一区二区三区在线观看 | 国产成人精品一区二| 久久免费视频色| 成人视屏免费看| 亚洲女同女同女同女同女同69| 日本电影欧美片| 一区二区成人在线| 日韩欧美三级在线| 成人av在线资源| 亚洲精品高清在线| 欧美一区二区三区视频在线观看 | 4438亚洲最大| 久久国产精品99精品国产| 久久久久久**毛片大全| av电影在线不卡| 五月天激情小说综合| 日韩欧美一卡二卡| fc2成人免费人成在线观看播放| ...xxx性欧美| 91精品国产91久久综合桃花| 国产一区在线精品| 亚洲欧美日韩国产一区二区三区| 宅男噜噜噜66一区二区66| 精品亚洲免费视频| 亚洲精品国产a| 日韩精品一区国产麻豆| 91女厕偷拍女厕偷拍高清| 日日摸夜夜添夜夜添精品视频 | 国产一区二区三区免费看| 亚洲国产高清不卡| 欧美一区二区三区免费| 欧美日韩一区视频| 精品一区二区在线播放| 亚洲日本免费电影| 亚洲欧美经典视频| 91精品国产欧美一区二区| 国产成人精品亚洲日本在线桃色| 一区二区三区中文字幕在线观看| 精品粉嫩超白一线天av| 欧美性受xxxx黑人xyx性爽| 国产成人自拍高清视频在线免费播放| 亚洲精品视频在线| 国产精品污网站| 精品国产污网站| 欧美日韩国产一二三| 91亚洲国产成人精品一区二区三 | 粉嫩av一区二区三区粉嫩| 亚洲不卡av一区二区三区| 欧美国产视频在线| 26uuu欧美| 日韩欧美综合一区| 欧美精品乱码久久久久久| 99精品视频一区| 高清不卡一二三区| 国产一本一道久久香蕉| 全国精品久久少妇| 午夜电影一区二区三区| 亚洲一区二区三区四区中文字幕| 亚洲区小说区图片区qvod| 国产精品久久久久久户外露出 | 欧美mv日韩mv国产| 欧美一级欧美一级在线播放| 欧美在线免费视屏| 在线观看日韩电影| 91久久免费观看| 欧美天堂一区二区三区| 色屁屁一区二区| 91丝袜美女网| 在线欧美小视频| 欧美性三三影院| 欧美精品自拍偷拍| 91精品国产91综合久久蜜臀| 日韩一区二区三区在线观看| 欧美不卡一区二区| 欧美tk丨vk视频| 国产精品污网站| 一二三区精品视频| 丝袜a∨在线一区二区三区不卡| 午夜天堂影视香蕉久久| 日韩成人av影视| 国产美女视频一区| 成人aa视频在线观看| 色婷婷av一区二区三区软件 | 欧美mv日韩mv国产网站app| 欧美大片拔萝卜| 国产精品毛片无遮挡高清| 亚洲欧洲日产国产综合网| 亚洲另类色综合网站| 亚洲超碰精品一区二区| 久草在线在线精品观看| 国产精品自产自拍| 91国产福利在线| 日韩一区二区三区电影在线观看| 精品欧美一区二区久久| 亚洲国产成人在线| 五月综合激情网| 国产一区二区女| 一本色道综合亚洲| 欧美一级日韩不卡播放免费| 久久久精品日韩欧美| 一区二区在线观看视频| 日韩精品一二三四| 国产aⅴ精品一区二区三区色成熟| jvid福利写真一区二区三区| 欧美日韩一区 二区 三区 久久精品 | 日韩欧美区一区二| 综合久久给合久久狠狠狠97色| 亚洲午夜久久久久久久久电影网| 久久99热这里只有精品| 99久久精品99国产精品| 欧美一区二区三区人| 综合久久久久综合| 国内精品久久久久影院一蜜桃| 在线视频一区二区免费| 欧美极品xxx| 激情久久五月天| 欧美精品亚洲二区| 亚洲精品国产精华液| 国产精品白丝jk白祙喷水网站|