【Flutter混编】基于WebViewJavascriptBridge的flutter与H5桥接方案

应用场景

目前使用Flutter对APP的部分页面进行改写,在原生基础上展示Flutter页面。其中遇到了打开的Flutter页面(WebView)无法响应H5桥接的问题。

按照网上的方案,WebView和H5的桥接交互主要通过JavascriptChannel实现

WebView(
     javascriptChannels: <JavascriptChannel>[ 
        _alertJavascriptChannel(context),
   ].toSet(),
)

JavascriptChannel _alertJavascriptChannel(BuildContext context) {
  return JavascriptChannel(
      name: 'Toast',
      onMessageReceived: (JavascriptMessage message) {
        showToast(message.message);
      });
}

但是在我们的项目中使用了WebViewJavascriptBridge进行桥接的封装,所以需要在Flutter端实现WebViewJavascriptBridge的处理逻辑。

设计方案

iOS有现成的WebViewJavascriptBridge的处理方案,尝试直接搬过来看看能不能跑。

需要理解WebViewJavascriptBridge实现的大致流程,主要是几个时间节点需要对应上:

1.创建桥接对象WebViewJavascriptBridge。这个直接在页面init里面初始化就行了,问题不大

_bridge = WebViewJavascriptBridge();

2.给WebViewJavascriptBridge绑定到一个页面上

iOS是在页面初始化中绑定的,Flutter页面中在WebView的onWebViewCreated绑定是比较合理的

onWebViewCreated: (WebViewController webViewController) {
    _webViewController = webViewController;
    _bridge.webViewController = _webViewController;
    _bridge.messageHandler = null;
    registerWebViewJavascriptBridgeHandler();
},

3.WebViewJavascriptBridge注册桥接方法。同上

4.WebViewJavascriptBridge通知前端启动

iOS是在webView:didFinishNavigation:(用的WKNavigationDelegate)回调中执行这一步的,对应WebView的onPageFinished

onPageFinished: (String url) {
    print('Page finished loading: $url');
    ///获取标题
    _webViewController.evaluateJavascript("document.title")
        .then((result){
            print(result);
            setState(() {
                widget.title = result;
            });
        });
    ///WebViewJavascriptBridge桥接相关 通知前端启动
    _bridge.webViewPageFinished();
},

5.WebViewJavascriptBridge监听页面发出的桥接请求

iOS是在webView:decidePolicyForNavigationAction:decisionHandler:中实现的,对应WebView的navigationDelegate

navigationDelegate: (NavigationRequest request) {
  print('allowing navigation to $request');
  String scheme = request.url.split("://")[0]??'';
  String host = request.url.split("://")[1]??'';
  if(scheme.compareTo('wvjbscheme') == 0) {
    if(host.compareTo('__WVJB_QUEUE_MESSAGE__') == 0) {
  
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值