在嵌入式 WebView 中设置 Dart 和 js 之间通信的通道

Posted

技术标签:

【中文标题】在嵌入式 WebView 中设置 Dart 和 js 之间通信的通道【英文标题】:Setting up a channel for communicating between Dart and js in an embedded WebView 【发布时间】:2019-05-25 23:41:26 【问题描述】:

需要在 OpenLayers 库之上构建具有地图功能的应用程序。这个应用程序是由两个平台(iosandroid)上的本地语言构建的,并且运行良好。现在,我们希望迁移到 Flutter 以获得“代码一次”术语的好处。除了 Flutter 团队开发的 webview 插件,Flutter 似乎是最好的选择。不支持dart和js的通信:-(。也在社区里翻了一些插件,但没有找到合适的。有人有好的想法,请指教。非常感谢!

【问题讨论】:

【参考方案1】:

我知道为时已晚,但它可能对其他人有所帮助。

这是一个从 javascript 代码到 Flutter 的通信示例。

在 Flutter 中构建您的 WebView,如下所示:

WebView(
          initialUrl: url,
          javascriptMode: JavascriptMode.unrestricted,
          javascriptChannels: Set.from([
            JavascriptChannel(
                name: 'Print',
                onMessageReceived: (JavascriptMessage message) 
                  //This is where you receive message from 
                  //javascript code and handle in Flutter/Dart
                  //like here, the message is just being printed
                  //in Run/LogCat window of android studio
                  print(message.message);
                )
          ]),
          onWebViewCreated: (WebViewController w) 
            webViewController = w;
          ,
        )

在您的 html 文件中:

<script type='text/javascript'>
Print.postMessage('Hello World being called from Javascript code');
</script>

当你运行这段代码时,你应该能够在 android studio 的 LogCat/Run 窗口中看到日志“Hello World being called from Javascript code”

如果您想将 msg 从 dart 发送到 js,那么这里是您的示例:-

 flutterWebviewPlugin.evalJavascript('var x = document.getElementsByClassName("layout__area--top"); x[0].style.opacity =0;');

【讨论】:

以上是关于在嵌入式 WebView 中设置 Dart 和 js 之间通信的通道的主要内容,如果未能解决你的问题,请参考以下文章

如何在 iOS 的 WebView(react-native-webview) 中设置自定义字体?

如何在iOS中设置方向变化的webview框架?

如何在 WebView2 中设置基于选项卡的 cookie?

iphone:如何在 webView 中设置字体大小?

如何在精灵套件中设置类别掩码?

在嵌入式Jetty中设置默认字符编码和内容类型