WebViewJavascriptBridge使用说明(iOS)
来源:互联网 发布:东莞厂货aj哪淘宝店好 编辑:程序博客网 时间:2024/06/15 01:35
因为最近项目需要跨平台,在网上找到这个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; }
- [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."];
暂时总结了这么些。下面有demo大家可以自己看看。有什么不懂的欢迎留言。
原文网址:http://dxldy.iteye.com/blog/2078350?utm_source=tuicool&utm_medium=referral
- WebViewJavascriptBridge使用说明(IOS)
- WebViewJavascriptBridge使用说明(IOS)
- WebViewJavascriptBridge使用说明(iOS)
- IOS-WebViewJavascriptBridge使用说明
- IOS-WebViewJavascriptBridge使用说明
- iOS和JS互调--WebViewJavascriptBridge使用说明
- OC-JS交互(WebViewJavascriptBridge使用说明)
- iOS WebViewJavascriptBridge 的使用
- iOS WebViewJavascriptBridge的使用
- WebViewJavascriptBridge使用(ios自学笔记)
- iOS源码解析—WebViewJavascriptBridge
- WebViewJavascriptBridge
- WebViewJavascriptBridge
- WebViewJavascriptBridge
- IOS 开发OC 与JS 交互 WebviewJavaScriptBridge 的简单实用(二)
- iOS下JS与OC互相调用(五)--UIWebView + WebViewJavascriptBridge
- iOS下JS与OC互相调用(六)--WKWebView + WebViewJavascriptBridge
- iOS下JS与OC互相调用(五)-->UIWebView + WebViewJavascriptBridge
- Java:按值传递还是按引用传递详细解说
- VidPN Objects and Interfaces
- C++内存管理
- Python语言下的机器学习库
- LISTAGG函数
- WebViewJavascriptBridge使用说明(iOS)
- Oracle EBS 11i BOM模块常用表结构
- 091.Block And Var 块与局部变量
- 那些年使用的测试工具
- Unity3D中使用easyroad3d插件 删除道路
- 090.Block 定义块的三种方式
- 函数式编程--方法和构造器引用
- 中文分词测试
- CvArr、Mat、CvMat、IplImage、BYTE转换(总结而来)