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

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

    下面来说一下WebViewJavascriptBridge在ios端怎么样使用。

    首先确保一份已经配好功能的html文件。(html还在学习阶段,暂时就不卖弄了。。。)

    1.初始化一个webview(viewdidload)

    OC代码

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

    [self.view addSubview:webView];

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

    OC代码

    if (_bridge) { return; }

    [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)

    OC代码

    [_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那边的返回值)

    OC代码

    id data = @{ @"greetingFromObjC": @"Hi there, JS!"};

    [_bridge callHandler:@"testJavascriptHandler"

                  data:data 

                  responseCallback:^(id response) {

                            NSLog(@"testJavascriptHandler responded: %@", response);

    }];

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

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

    OC代码

    [_bridge send:@"A string sent from ObjC to JS"

                  responseCallback:^(id response) {

                            NSLog(@"sendMessage got response: %@", response);

    }];

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

    OC代码

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

    暂时总结了这么些。下面有demo大家可以自己看看。有什么不懂的欢迎留言。



    文/Stevin_Y(简书作者)
    原文链接:http://www.jianshu.com/p/b723e2be37c7
    著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
  • 相关阅读:
    SQL函数——CASE
    初始Oracle
    ASP.NET中JQuery+AJAX调用后台
    性能优化——SQL语句(续)
    性能优化——SQL语句
    今日开讲—— easyui-combobox动态赋值
    SSH 项目建立过程
    Util
    前端 s 标签获取值
    日期选择文本框
  • 原文地址:https://www.cnblogs.com/meixian/p/6171983.html
Copyright © 2011-2022 走看看