WebViewJavascriptBridge使用说明(iOS)

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

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

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

1.初始化一个webview(viewdidload)学习

OC代码code

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

[self.view addSubview:webView];ip

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

OC代码开发

if (_bridge) { return; }string

[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 著做权归做者全部,转载请联系做者得到受权,并标注“简书做者”。
相关文章
相关标签/搜索