我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Flutter web bridge通信方式是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Flutter web bridge通信方式是什么

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

    架构图大致如下

    Flutter web bridge通信方式是什么

    bridge 部分解决各端的

    • 兼容性和平台差异

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

    • 各端之间跨端通信

    • 第三方 SDK 调用整合

    • 各端业务复用

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

    通信方式

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

    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通信方式是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Flutter web bridge通信方式是什么

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

    下载Word文档

    猜你喜欢

    Flutter web bridge通信方式是什么

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

    web前端实时通信的方式是什么

    这篇“web前端实时通信的方式是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“web前端实时通信的方式是什么”文章吧。1
    2023-06-30

    Vue组件的通信方式是什么

    本篇内容主要讲解“Vue组件的通信方式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue组件的通信方式是什么”吧!组件间通信的概念开始之前,我们把组件间通信这个词进行拆分组件通信都知道组
    2023-07-06

    Vue组件间通信方式是什么

    这篇文章将为大家详细讲解有关Vue组件间通信方式是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。通信方式:1、用props通信;2、用“$emit”通信;3、用ref通信;4、用EventBus通信;
    2023-06-29

    Java线程通信中wait-notify通信的方式是什么

    这篇文章主要介绍“Java线程通信中wait-notify通信的方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java线程通信中wait-notify通信的方式是什么”文章能帮助大家解决问
    2023-06-29

    Linux进程间通信的方式是什么

    本篇内容主要讲解“Linux进程间通信的方式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux进程间通信的方式是什么”吧!·进程间通信:操作系统为系统提供的用于实现进程间通信的方式进
    2023-06-29

    Python进程间的通信方式是什么

    这篇文章主要介绍“Python进程间的通信方式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python进程间的通信方式是什么”文章能帮助大家解决问题。什么是进程的通信这里举一个例子接介绍通信
    2023-06-29

    Vue组件之间的通信方式是什么

    本篇内容介绍了“Vue组件之间的通信方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、组件间通信的概念开始之前,我们把组件间通信这
    2023-07-02

    Visual Web Developer Web创建方式是什么

    今天就跟大家聊聊有关Visual Web Developer Web创建方式是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。组合使用Visual Web Developer We
    2023-06-17

    VUE父子组件通信的未来:下一代通信方式是什么?

    VUE父子组件通信是一种常用的组件通信方式,但它存在一些局限性。下一代通信方式是什么?本文将探讨这个问题,并介绍一些新的组件通信方式。
    VUE父子组件通信的未来:下一代通信方式是什么?
    2024-02-07

    React中组件之间通信的方式是什么

    本篇内容介绍了“React中组件之间通信的方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、是什么我们将组件间通信可以拆分为两个词
    2023-06-20

    vue的通信方法是什么

    今天小编给大家分享一下vue的通信方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。通信方法:1、子组件设置props
    2023-07-04

    Linux系统进程通信的主要方式是什么

    Linux系统进程通信的主要方式是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。概览进程间通信常见方式如下:管道FIFO消息队列信号量共享内存UNXI域套接
    2023-06-28

    计算机中即时通信是一种以什么方式为主的通信服务

    小编给大家分享一下计算机中即时通信是一种以什么方式为主的通信服务,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!即时通信是一种以“同步通信”方式为主进行消息交换的通
    2023-06-06

    web前后端交互方式是什么

    这篇文章主要讲解了“web前后端交互方式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“web前后端交互方式是什么”吧!  正如我们所知,一个完整的IT项目是由多个不同岗位共同完成的,包
    2023-06-27

    Java NIO Socket通信的方法是什么

    这篇文章主要讲解了“Java NIO Socket通信的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java NIO Socket通信的方法是什么”吧!服务器代码:import
    2023-06-17

    Linux进程通信的方法是什么

    本篇内容介绍了“Linux进程通信的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Linux进程通信具体方法1.管道管道分为有名管
    2023-06-28

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录