因为如今不少产品都是有安卓版跟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你们能够本身看看。有什么不懂的欢迎留言。