zoukankan      html  css  js  c++  java
  • WebViewJavascriptBridge使用说明(IOS)

          因为最近项目需要跨平台,在网上找到这个demo拿来用。首先简单说一下跨平台:由于现在很多产品都是有安卓版跟ios版,就意味着同一样东西要出两套,由两组人去完成,不仅增加了开发成本,也大大加剧了维护成本。聪明的coder想出了跨平台的思路,用html写页面,分别用webview(ios),(安卓)来加载,对某些html无法调用的硬件,通过双方的交互来实现方法的互调和传值。这个过程就是跨平台。

      下面来说一下WebViewJavascriptBridge在ios端怎么样使用。首先确保一份已经配好功能的html文件。(html还在学习阶段,暂时就不卖弄了。。。)

      1.初始化一个webview(viewdidload)

    UIWebView* webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
    [self.view addSubview:webView];
    

       2.将此webview与WebViewJavascriptBridge关联(viewdidload)

    if (_bridge) { return; }
        UIWebView* webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
        [self.view addSubview:webView];
        [WebViewJavascriptBridge enableLogging];
        _bridge = [WebViewJavascriptBridge bridgeForWebView:webView webViewDelegate:self handler:^(id data, WVJBResponseCallback responseCallback) {
            NSLog(@"ObjC received message from JS: %@", data);
            responseCallback(@"Response for message from ObjC");
            
        }];
    

      ps:此时你的webview就与js搭上桥了。下面就是方法的互调和参数的互传。

    (1) js调oc方法(可以通过data给oc方法传值,使用responseCallback将值再返回给js)

    [_bridge registerHandler:@"testObjcCallback" handler:^(id data, WVJBResponseCallback responseCallback) {
            NSLog(@"testObjcCallback called: %@", data);
            responseCallback(@"Response from testObjcCallback");
        }];
    

     这里注意testObjcCallback这个方法的标示。html那边的命名要跟ios这边相同,才能调到这个方法。当然这个名字可以两边商量着自定义。简单明确即可。

    (2)oc调js方法(通过data可以传值,通过  response可以接受js那边的返回值 )

    id data = @{ @"greetingFromObjC": @"Hi there, JS!" };
        [_bridge callHandler:@"testJavascriptHandler" data:data responseCallback:^(id response) {
            NSLog(@"testJavascriptHandler responded: %@", response);
        }];
    

     注意这里的  testJavascriptHandler也是个方法标示。

    (3)oc给js传值(通过  response接受返回值 )

    [_bridge send:@"A string sent from ObjC to JS" responseCallback:^(id response) {
            NSLog(@"sendMessage got response: %@", response);
        }];
    

     (4)oc给js传值(无返回值)

    [_bridge send:@"A string sent from ObjC after Webview has loaded."];
    

     源码下载地址:https://github.com/marcuswestin/WebViewJavascriptBridge

     源码原理解析:http://www.2cto.com/kf/201503/384998.html

  • 相关阅读:
    java学习笔记----数据类型,变量,常量
    java学习笔记 --- java基础语法
    java学习笔记----java入门
    python 类方法
    nginx 限制ip/限制访问路径
    python 异常处理
    python 内置模块
    python 模块与包
    python函数基础用法
    python函数高级运用
  • 原文地址:https://www.cnblogs.com/FightingLuoYin/p/4583194.html
Copyright © 2011-2022 走看看