harmony鸿蒙下实现bc交互的方式和方法

前言

最近在研究harmony操作系统下的交互,因此写一篇文章记录一下。

解决的问题

本篇文章主要是来写解决如果兼容android或者ios的交互,这样子避免h5页面的二次开发,节省资源。

交互的种类

交互对于harmony来说其实只有一种,只有注册的形式,使用WebviewController的registerJavaScriptProxy来实现,如果是从头开始开发harmony 是没有任何问题的,直接使用这个来写就行。

但是如果你的项目中有大量的h5页面,使用了很多的交互,这时怎么能够兼容呢,我们想到了一些办法。

模拟android

我们在WebviewController的setCustomUserAgent方法中把安卓完整的ua和harmony的ua拼接在一起,这样子,前端h5的交互就以为是安卓的请求,就会根据android的形式来处理交互,ios同理。

代码如下:

dart 复制代码
  this.webviewController.setCustomUserAgent("F-OFST moblie_android" + this.androidUa + this.webviewController.getUserAgent())
    this.webviewController.registerJavaScriptProxy(this.myUtilsRegisterBridge, "Myutils",
      ["return_btn", "returnBack", "returnLogin"]);
      

但是android还有一种实现bc交互的方法,就是利用浏览器的onPrompt机制,这种机制就是我们利用event的message和value,来制定前端给我们的格式,比如,key,callbakc(回调函数),params(参数),利用这些定义好的值,在客户端接收到后,进行解析,如果是正常的返回就用

result.handlePromptConfirm(json);或者result.handleConfirm();来实现,

如果是callback我们可以使用this.webviewController的runJavaScript来实现,或者使用this.webviewController的loadurl来实现,代码如下:

dart 复制代码
   this.mWebviewController.loadUrl("javascript:" + webViewJSBean.callBack + "(" + tmpStr + ")")
      

总结

到此就结束了,这里主要的重点是

一、解决如何节省资源的情况下实现harmony的交互,

二、利用onPrompt实现交互,我们称为拦截

三、this.mWebviewController.loadUrl实现回调函数,这种在文档里是查不到的,在此记录,为后面的人铺路

相关推荐
盐焗西兰花6 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos
方见华Richard10 小时前
自指-认知几何架构 可行性边界白皮书(务实版)
人工智能·经验分享·交互·原型模式·空间计算
lbb 小魔仙10 小时前
【HarmonyOS实战】React Native 表单实战:在 OpenHarmony 上构建高性能表单
react native·华为·harmonyos
一只大侠的侠13 小时前
React Native开源鸿蒙跨平台训练营 Day16自定义 useForm 高性能验证
flutter·开源·harmonyos
子春一13 小时前
Flutter for OpenHarmony:绿氧 - 基于Flutter的呼吸训练应用开发实践与身心交互设计
flutter·交互
早點睡39014 小时前
高级进阶 React Native 鸿蒙跨平台开发:@react-native-community-slider 滑块组件
react native·react.js·harmonyos
一只大侠的侠14 小时前
Flutter开源鸿蒙跨平台训练营 Day11从零开发商品详情页面
flutter·开源·harmonyos
一只大侠的侠14 小时前
React Native开源鸿蒙跨平台训练营 Day18自定义useForm表单管理实战实现
flutter·开源·harmonyos
一只大侠的侠15 小时前
React Native开源鸿蒙跨平台训练营 Day20自定义 useValidator 实现高性能表单验证
flutter·开源·harmonyos
听麟15 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务