iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Flutter web bridge通信方式是什么
  • 243
分享到

Flutter web bridge通信方式是什么

2023-07-05 01:07:54 243人浏览 独家记忆
摘要

这篇文章主要介绍“Flutter WEB bridge通信方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter web bridge通信方式

这篇文章主要介绍“Flutter WEB bridge通信方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter web bridge通信方式是什么”文章能帮助大家解决问题。

    架构图大致如下

    Flutter web bridge通信方式是什么

    bridge 部分解决各端的

    • 兼容性和平台差异

    • 不同操作系统之间的处理

    • 各端之间跨端通信

    • 第三方 SDK 调用整合

    • 各端业务复用

    • 解决各端之间 Auth 的授权整合

    通信方式

    老生常谈了 其实就是 jsdart 之间的相互调用和注入方法

    APP 中 JS & dart call

    • APP 中

    app中主要是通过 webview 来通信和混合开发的方式大同小异;都是 H5 & App 各自注册通过 postmessage | urlchange 来触发调用

    主要代码:

    通过 Flutter webview中注入 flutter 的方法

    Flutter端

    javascriptChannels: <JavascriptChannel>[                  JavascriptChannel(                    name: 'xxBridge',                    onMessageReceived: (JavascriptMessage jsMessage) {                      Map messageMap = JSON.decode(jsMessage.message);                      print(messageMap);                      if (messageMap['type'] == 'appPagePop') {                        Navigator.pop(context, messageMap['value']);                        return;                      }                      if (messageMap['type'] == 'navigateTo') {                        Map params = messageMap['params'];                        String patientCode = params['code'];                        Routes.navigateTo(context, messageMap['url'],                            params: {'id': UserUtil.transferCodeToId(patientCode)});                        return;                      }                    },                  ),                ].toSet()
    • H5端

    export default class xxBridge {  isApp: boolean;  constructor() {        window.flutterMessage = (message: string) => {      console.log(message, ' receipt app message');      return true;    };  }  appPagePop = (value = false) => {    if (!this.isApp) {      console.log('当前不是app环境,或者没有Bridge 运行时哦 ~ !');      window.history.back();      return;    }    window.xxBridge.postMessage(      JSON.stringify({        type: 'appPagePop',        value: value,      }),    );  };}
    • Flutter 中调用 H5 在window 注册的方法

    onPageFinished: (url) {                  print(url + '加载完成');                  Map data = {                    'doctorCode': UserUtil.doctorCode(),                    'doctorName': SpUtil.getString(DOCTOR_NAME_KEY),                  };                  var dataJson = json.encode(data);                  print(dataJson);                  _webviewController?.evaluateJavascript("getAppLoginInfo('$dataJson')").then((res) {                    print("evaluateJavascript-res: ${res}"); // evaluateJavascript-res: true                  });                  // print('加载结束');                },
    • xxBridgeFlutter JavascriptChannel 注入通信对象

    • onMessageReceived 接收 web端 postmessage 触发 dart 方法

    • web 端中 window.flutterMessage 注册方法给 Flutter 在 app 中调用

    至此 Flutter APP 和 H5 通信 基本是以上方式拓展,当然还有 Url 的方式 和 Storage 的方式这里不表;

    Flutter web 中 JS & dart call

    dart 调用 js

    有2种方式

    1. Promise js文件的方式被调用

    定义方法

    function print(msg) {  return new Promise((resolve, reject) => {     resolve('code : xxxxx')    alert(msg)  });}

    调用

    import 'dart:js' as js;@JS()external print(String msg);var wxScanPromise = print('123');String code = await jsUtil.promiseToFuture(wxScanPromise)

    2. 通过 js.context 获取上下文来调用

    • 首先在 init 中注入方法

    webapp main.dart

    class Application {  static Future init(ui.VoidCallback callback) async {    DarttoJS().into();     }  ...}
    //  This's a test dart to js funcclass DarttoJS {  // js call dart  static void myalert(String text) {    Fluttertoast.showToast(        msg: "This's JS pass on test !:$text",        toastLength: Toast.LENGTH_SHORT,        gravity: ToastGravity.CENTER,        timeInSecForiOSWeb: 1,        backgroundColor: Colors.red,        textColor: Colors.white,        fontSize: 16.0);  }  void into() {    js.context["myalert"] = myalert;    js.context.callMethod('onLogin');  }}

    webaapp index 文件中添加 onLogin

    const onLogin = () => {    ...}export { onLogin }
    • 在 init 中注入方法调用类

    • js.context 来给 js 注入window下的全局方法

    js 调用 dart

    • 通过 js.context["myalert"] = myalert 注册了方法

    • 直接在js文件中调用

    summary

    之后我们可以在 xxBridge 中不断的继承 WeChat SDK、dingdingSDK、等等 和一些业务方法 通过 rollup 等一些工具 打包发布NPM包。

    关于“Flutter web bridge通信方式是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

    --结束END--

    本文标题: Flutter web bridge通信方式是什么

    本文链接: https://www.lsjlt.com/news/348678.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Flutter web bridge通信方式是什么
      这篇文章主要介绍“Flutter web bridge通信方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Flutter web bridge通信方式...
      99+
      2023-07-05
    • web前端实时通信的方式是什么
      这篇“web前端实时通信的方式是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“web前端实时通信的方式是什么”文章吧。1...
      99+
      2023-06-30
    • Vue组件的通信方式是什么
      本篇内容主要讲解“Vue组件的通信方式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue组件的通信方式是什么”吧!组件间通信的概念开始之前,我们把组件间通信这个词进行拆分组件通信都知道组...
      99+
      2023-07-06
    • Java线程通信中wait-notify通信的方式是什么
      这篇文章主要介绍“Java线程通信中wait-notify通信的方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java线程通信中wait-notify通信的方式是什么”文章能帮助大家解决问...
      99+
      2023-06-29
    • Vue组件间通信方式是什么
      这篇文章将为大家详细讲解有关Vue组件间通信方式是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。通信方式:1、用props通信;2、用“$emit”通信;3、用ref通信;4、用EventBus通信;...
      99+
      2023-06-29
    • Python进程间的通信方式是什么
      这篇文章主要介绍“Python进程间的通信方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python进程间的通信方式是什么”文章能帮助大家解决问题。什么是进程的通信这里举一个例子接介绍通信...
      99+
      2023-06-29
    • Linux进程间通信的方式是什么
      本篇内容主要讲解“Linux进程间通信的方式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux进程间通信的方式是什么”吧!·进程间通信:操作系统为系统提供的用于实现进程间通信的方式进...
      99+
      2023-06-29
    • uni-app组件通信的方式是什么
      这篇文章主要介绍“uni-app组件通信的方式是什么”,在日常操作中,相信很多人在uni-app组件通信的方式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”uni-ap...
      99+
      2024-04-02
    • WebSocket的通信模式是什么
      今天小编给大家分享一下WebSocket的通信模式是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来...
      99+
      2024-04-02
    • Vue组件之间的通信方式是什么
      本篇内容介绍了“Vue组件之间的通信方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、组件间通信的概念开始之前,我们把组件间通信这...
      99+
      2023-07-02
    • Visual Web Developer Web创建方式是什么
      今天就跟大家聊聊有关Visual Web Developer Web创建方式是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。组合使用Visual Web Developer We...
      99+
      2023-06-17
    • VUE父子组件通信的未来:下一代通信方式是什么?
      父子组件通信是VUE中一种常用的组件通信方式,它允许父组件直接访问子组件的数据和方法。这种通信方式简单易用,但它存在一些局限性。例如,它只能在父子组件之间进行通信,而且父组件不能访问子组件的内部状态。 为了解决这些问题,下一代组件通信方...
      99+
      2024-02-07
      VUE 组件通信 父子组件通信 下一代组件通信
    • React中组件之间通信的方式是什么
      本篇内容介绍了“React中组件之间通信的方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、是什么我们将组件间通信可以拆分为两个词...
      99+
      2023-06-20
    • vue的通信方法是什么
      今天小编给大家分享一下vue的通信方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。通信方法:1、子组件设置props...
      99+
      2023-07-04
    • Linux系统进程通信的主要方式是什么
      Linux系统进程通信的主要方式是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。概览进程间通信常见方式如下:管道FIFO消息队列信号量共享内存UNXI域套接...
      99+
      2023-06-28
    • 计算机中即时通信是一种以什么方式为主的通信服务
      小编给大家分享一下计算机中即时通信是一种以什么方式为主的通信服务,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!即时通信是一种以“同步通信”方式为主进行消息交换的通...
      99+
      2023-06-06
    • Linux进程通信的方法是什么
      本篇内容介绍了“Linux进程通信的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Linux进程通信具体方法1.管道管道分为有名管...
      99+
      2023-06-28
    • Java NIO Socket通信的方法是什么
      这篇文章主要讲解了“Java NIO Socket通信的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java NIO Socket通信的方法是什么”吧!服务器代码:import&...
      99+
      2023-06-17
    • c++串口通信的方法是什么
      在C++中进行串口通信,通常需要使用串口通信库来实现。其中,常用的串口通信库包括Boost.Asio和Qt Serial Port等...
      99+
      2024-04-02
    • vue3组件间怎么通信?通信方式浅析
      在我们写 vue3 的项目中,我们都会进行组件通信,我们除了使用 pinia 公共数据源的方式除外,我们还可采用那些更简单的API方法呢?那下面我就来给大家介绍介绍几种父子组件和子父组件通信的方式。1、父子组件通信1.1 definePro...
      99+
      2023-05-14
      组件通信 Vue
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作