WebViewJavascriptBridge使用说明(IOS)
2015-06-17 14:17
579 查看
因为最近项目需要跨平台,在网上找到这个demo拿来用。首先简单说一下跨平台:由于现在很多产品都是有安卓版跟ios版,就意味着同一样东西要出两套,由两组人去完成,不仅增加了开发成本,也大大加剧了维护成本。聪明的coder想出了跨平台的思路,用html写页面,分别用webview(ios),(安卓)来加载,对某些html无法调用的硬件,通过双方的交互来实现方法的互调和传值。这个过程就是跨平台。
下面来说一下WebViewJavascriptBridge在ios端怎么样使用。首先确保一份已经配好功能的html文件。(html还在学习阶段,暂时就不卖弄了。。。)
1.初始化一个webview(viewdidload)
2.将此webview与WebViewJavascriptBridge关联(viewdidload)
ps:此时你的webview就与js搭上桥了。下面就是方法的互调和参数的互传。
(1) js调oc方法(可以通过data给oc方法传值,使用responseCallback将值再返回给js)
这里注意testObjcCallback这个方法的标示。html那边的命名要跟ios这边相同,才能调到这个方法。当然这个名字可以两边商量着自定义。简单明确即可。
(2)oc调js方法(通过data可以传值,通过 response可以接受js那边的返回值 )
注意这里的 testJavascriptHandler也是个方法标示。
(3)oc给js传值(通过 response接受返回值 )
(4)oc给js传值(无返回值)
源码下载地址:https://github.com/marcuswestin/WebViewJavascriptBridge
源码原理解析:http://www.2cto.com/kf/201503/384998.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
相关文章推荐
- iOS原生二维码扫描
- Android framework系统默认设置修改
- Android textView文字添加图片 imageSpan使用
- Android中GridView中onTouch监听(1)item实现触摸执行缩放动画的功能
- 【某deed和某app面试】
- Ios开发必看,苹果粉绝不能错过
- Android L——Material Design详解(视图和阴影)
- Android: 创建一个AlertDialog对话框,必须按确定或取消按钮才能关闭对话框,禁止按[返回键]或[搜索键]关闭
- Android: 清除View跳转的历史记录
- Hisi3716C Android解决方案问题记录
- LeetCode之“数学”:Happy Number
- iOS 使用ZBarSDK扫描条形码和二维码
- [iOS学习]NSPredicate
- Android: 待机时如何让程序继续运行 extends Service
- Android: View换切后,无法正常设置焦点或切换后TextView的虚拟键盘不弹出
- cocos2d-x安装
- [Unity3D]Stencil buffer失效了怎么办
- 修改android usb的VID PID
- 消除“Android NDK: WARNING: APP_PLATFORM”的方法
- SpringMVC+Hibernate CRUD Application