您现在的位置是:网站首页> 编程资料编程资料
Html5与App的通讯方式详解详解HTML5通讯录获取指定多个人的信息 html5跨域通讯之postMessage的用法总结
2021-08-31
978人已围观
简介 这篇文章主要介绍了Html5与App的通讯方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
前言
现在不管是桌面客户端还是移动客户端,都会夹杂着一部分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 ( ); } 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 ( {this.state.list.map(v =>- {v}
)}
; ); } addNum(num) { this.setState(prevState => ({ list: prevState.list.concat(num); })); } } 以上在组件加载完成后通过window.addNum = this.addNum.bind(this)将指定方法全局暴露到window上,App Webview可直接操作这些方法来控制H5页面。
结语
写到最后总结得差不多了,后续如果我想起还有哪些H5与App的通讯方式遗漏的,会继续在这篇文章上补全,同时也希望各位朋友对文章里的要点进行补充或者提出自己的见解。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- html+js 实现markdown编辑器效果HTML5高仿微信聊天、微信聊天表情|对话框|编辑器功能html5使用Drag事件编辑器拖拽上传图片的示例代码基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
- 高清屏下canvas重置尺寸引发的问题的解决浅析canvas元素的html尺寸和css尺寸对元素视觉的影响html5中canvas学习笔记1-画板的尺寸与实际显示尺寸
- HTML table 表格边框的实现思路html中table表格的内容水平和垂直居中显示详解HTML中table表格的frame和rules属性Div+CSS对HTML的table表格定位用法实例深入解析HTML的table表格标签与相关的换行问题html 隐藏div HTML里隐藏表格TABLE或者DIV内容的css样式HTML table表格边框的控制详细说明HTML的dl、dt、dd标记制作表格对决Table制作表
- Html5自定义字体解决方法html5 canvas绘制网络字体的常用方法使用HTML5 Canvas API控制字体的显示与渲染的方法HTML5时代CSS设置漂亮字体取代图片
- webView加载html图片遇到的问题解决HTML5 图片预加载的示例代码利用简洁的图片预加载组件提升html5移动页面的用户体验 html5实现的页面滚动图片动画加载特效源码HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影基于HTML代码实现图片碎片化加载功能
- 使用postMessage让 iframe自适应高度的方法示例web响应式布局中iframe自适应的方法iframe 多层嵌套 无限嵌套 高度自适应的解决方案网页设计技巧:iframe自适应高度的问题iframe标签用法详解(属性、透明、自适应高度)三谈Iframe自适应高度代码Iframe 高度自适应(兼容IE/Firefox、同域/跨域)iframe 自适应大小实现代码
- 基于 HTML5 WebGL 实现的医疗物流系统HTML5播放实现rtmp流直播html5用video标签流式加载的实现Html5 实现微信分享及自定义内容的流程HTML5 canvas 瀑布流文字效果的示例代码HTML5移动端手机网站开发流程HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影HTML5梦幻之旅——炫丽的流星雨效果实现过程HTML5 离线应用之打造零请求、无流量网站的解决方法Html5之webcoekt播放JPEG图片流
- html2canvas生成清晰的图片实现打印的示例代码html2 canvas生成清晰的图片实现打印功能前端实现打印图像功能一个不错的html 打印代码支持翻页CSS2 打印属性让打印HTML文档不出问题将XHTML CSS页面转换为打印机页面将XHTML CSS页面转换为打印机页面html 打印相关操作与实现详解
- 吃透移动端 Html5 响应式布局html5移动端自适应布局的实现HTML5 通过Vedio标签实现视频循环播放的示例代码HTML5中在title标题标签里设置小图标的方法html5用video标签流式加载的实现详解HTML5 Canvas标签及基本使用html5自定义video标签的海报与播放按钮功能详解HTML5布局和HTML5标签
- HTML文本属性&颜色控制属性的实现html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
点击排行
本栏推荐
