iOS原生APP与H5+JS交互////////////////////zzzz
原生代码中直接加载页面
1. 具体案例
加载本地/网络HTML5作为功能介绍页
2. 代码示例
//本地
- -(void)loadLocalPage:(UIWebView*)webView
- {
- NSString* htmlPath = [[NSBundle mainBundle]pathForResource:@"demo" ofType:@"html"];
- NSString* appHtml =[NSString stringWithContentsOfFile:htmlPath encoding:NSUTF8StringEncodingerror:nil];
- NSURL *baseURL = [NSURLfileURLWithPath:htmlPath];
- [webView loadHTMLString:appHtmlbaseURL:baseURL];
- }
//网络
- -(void)loadWebPage:(UIWebView *)webView
- {
- NSURL *url = [NSURLURLWithString:@"http://www.baidu.com"];
- NSURLRequest *request = [NSURLRequestrequestWithURL:url];
- [webView loadRequest:request];
- }
3. 额外操作
a iOS中承载网页的容器是UIWebView,可以借助它的代理来监听网页加载情况;
b 在加载过程中,我们还可以获取该网页中的meta值,例如代码:
- NSString *shareUrl = [messWebViewstringByEvaluatingJavaScriptFromString:@"document.getElementsByName(\"shareUrl\")[0].content"];
就是从meta中得到shareUrl对应的value值;
c 截获当前是发起的那种请求,以便native来做对应的控制,例如代码:
- - (BOOL)webView:(UIWebView*)webView shouldStartLoadWithRequest:(NSURLRequest *)requestnavigationType:(UIWebViewNavigationType)navigationType
- {
- NSString *requestString = [[[request URL]absoluteString]stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
- if ([requestString hasPrefix:@"http://customersharetrigger"]){
- //执行一些操作
- return NO;
- }
- return YES;
- } //可以监听到这个请求,从而达到控制作用;
二、 原生代码操作页面元素
1. 具体案例
在嵌入H5后需要操作页面元素
2. 代码示例
a、获取当前页面的url。
- -(void)webViewDidFinishLoad:(UIWebView *)webView {
- NSString *currentURL = [webView stringByEvaluatingJavaScriptFromString:@"document.location.href"];
- }
b、获取页面title:
- NSString *currentURL = [webViewstringByEvaluatingJavaScriptFromString:@"document.location.href"];
- NSString *title = [webviewstringByEvaluatingJavaScriptFromString:@"document.title"];
c、修改界面元素的值。
- NSString *js_result = [webViewstringByEvaluatingJavaScriptFromString:@"document.getElementsByName('q')[0].value='朱祁林';"];
d、表单提交:
- NSString *js_result2 =[webView stringByEvaluatingJavaScriptFromString:@"document.forms[0].submit();"];
3. 代码说明
stringByEvaluatingJavaScriptFromString方法可以将javascript代码片段嵌入到页面中,通过这个方法就可以让iOS与UIWebView中的网页元素交互,例如上面的代码片段,它
功能非常的强大,用起来也相对简单,通过它我们可以很方便的操作页面元素,而且能直接插入一段JS方法,然后调用该方法执行;
三、 原生代码处理本地H5+JS
1. 具体案例
需要动态显示曲线图,如果直接加载绘制图形特别慢,所以采用本地放置模板,传入参数,然后模板自动绘制,提高体验,加快绘制;
2. 示例代码
- -(void)loadWebPage:(UIWebView *)webView
- {
- NSURL *localPathURL = [[NSBundlemainBundle] URLForResource:@"detail" withExtension:@"html"subdirectory:@"htmlResources"];
- NSString *localPathUrl = [localPathURLabsoluteString];
- NSString *localParamPathUrl = [NSStringstringWithFormat:@"%@?symbol=%@&t=%f",localPathUrl,self.stockCode,self.time];
- NSURL *requestURL = [NSURLURLWithString:localParamPathUrl];
- [webView loadRequest:[NSURLRequestrequestWithURL:requestURL]];
- }
3. 代码说明
a 这里需要采用绝对路径拖入H5模板,就是选择CreateFolder Reference, 只有这样才能保证H5能调用到本地的JS代码,不然加载不成功,这个最初找了很多原因,最后才发现是拖入时候选择问题;
b 如果要加入参数,注意需要先转成string,然后再转为URL;
四、 原生代码与网页交互通信
1. 具体案例
原生代码与H5相互调用方法,并传递参数,而且能回调数据;
2. 借助第三方实现
WebViewJavascriptBridge,该开源库非常完美的解决了原生代码与H5交互,即互殴;
3. 代码示例
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 = [WebViewJavascriptBridgebridgeForWebView:webView webViewDelegate:self handler:^(id data,WVJBResponseCallback responseCallback) {
- NSLog(@"ObjC received message from JS:%@", data);
- responseCallback(@"Response formessage from ObjC");
- }];
此时webview就与js搭上桥了。下面就是方法的互调和参数的互传。
(1) js调oc方法(可以通过data给oc方法传值,使用responseCallback将值再返回给js)
- [_bridgeregisterHandler:@"testObjcCallback" handler:^(id data,WVJBResponseCallback responseCallback) {
- NSLog(@"testObjcCallback called:%@", data);
- responseCallback(@"Response fromtestObjcCallback");
- }];
这里注意testObjcCallback这个方法的标示。html那边的命名要跟ios这边相同,才能调到这个方法。当然这个名字可以两边商量着自定义。简单明确即可。
(2)oc调js方法(通过data可以传值,通过 response可以接受js那边的返回值 )
- id data = @{@"greetingFromObjC": @"Hi there, JS!" };
- [_bridgecallHandler:@"testJavascriptHandler" data:data responseCallback:^(idresponse) {
- NSLog(@"testJavascriptHandlerresponded: %@", response);
- }];
注意这里的 testJavascriptHandler也是个方法标示。
(3)oc给js传值(通过 response接受返回值 )
- [_bridge send:@"Astring 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 hasloaded."];
五、 总结
关于Native和H5的交互有各种形式,随着H5越来越成熟,未来的趋势就是两者形影不离,让App更具灵活性和实效性,也一定程度上提高了开发效率和迭代周期,是企业级移动应用开发的必选解决方案,推荐:IT面试宝典(典型)
iOS原生APP与H5+JS交互////////////////////zzzz的更多相关文章
- iOS原生App与H5页面交互笔记
文/MikeZhangpy(简书作者)原文链接:http://www.jianshu.com/p/4ed3e5ed99c6著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 最近在做一个项 ...
- iOS原生APP和H5交互-delegate和第三方
一.原生代码中直接加载页面(拦截) 1. 具体案例 加载本地/网络HTML5作为功能介绍页 2. 代码示例 //本地 -(void)loadLocalPage:(UIWebView*)we ...
- 混合app开发,h5页面调用ios原生APP的接口
混合APP开发中,前端开发H5页面,不免会把兼容性拉进来,在做页面的兼容性同事,会与原生app产生一些数据交互: 混合APP开发,安卓的兼容性倒是好说,安卓使用是chrome浏览器核心,已经很好兼容H ...
- iOS原生和React-Native之间的交互1
今天,记录一下iOS原生和React-Native之间的交互.如果第一次接触最好先移步至 http://www.cnblogs.com/shaoting/p/6388502.html 先看一下怎么在i ...
- angularjs中安卓原生APP调用H5页面js函数,js写法应注意
安卓原生app调用js方法,js方法应写在html下的script标签内,不能有任何function包裹,例如angular的controller层,这样APP也是获取不到的: 所以只有放在html中 ...
- 使用HTML5构建iOS原生APP(2)
本文转载至 http://ju.outofmemory.cn/entry/18807 有时候我们在内嵌的webview中希望点击一个链接之后,触发iOS原生事件,而不是webview内页面跳转(因为w ...
- iOS原生和React-Native之间的交互2
今天看下iOS原生->RN: 这里有个问题: * 我这里只能通过rn->ios->rn来是实现* 如果想直接ios-rn 那个iOS中的CalendarManager的self.br ...
- Android 原生开发、H5、React-Native使用利弊和场景技术分享
http://m.blog.csdn.net/article/details?id=51778086 发表于2016/6/28 18:52:46 1176人阅读 最近工作中接触到React ...
- The Best One iOS Contacts App
The Best One iOS Contacts App iPhone Contacts App SwiftUI Awesome iOS Contacts App 一款高度还原华为通讯录 iOS A ...
随机推荐
- 关于Openlayer3的菜鸟认识
什么是OpenLayers? OpenLayers 是一个专为Web GIS 客户端开发提供的JavaScript 类库包,用于实现标准格式发布的地图数据访问.从OpenLayers2.2版本以后,O ...
- java分享第七天-03(递归打印文件目录的树状结构)
public static void main(String[] args) { File file= new File("e:/list"); printFile(file, 0 ...
- PHP TCPDF ERROR: [Image] Unable to get image解决办法详解
使用TCPDF输出pdf文件时,有时会直接显示pdf文件不可显示,仔细调试之下会报错TCPDF ERROR: [Image] Unable to get image.问题出现Image()函数中.第一 ...
- webform 复合控件
RadioButtonList 单选按钮列表 属性:RepeatColumns 用于布局项的列数(每一行的个数) RepeatDirection 选择Vertical,纵向排列:选择Horizont ...
- Web.xml各版本模版
web.xml v2.3 web.xml v2.4 <?xml version="1.0" encoding="UTF-8"?> <web-a ...
- #20145205 《Java程序设计》第5周学习总结
教材学习内容总结 1.java中的错误都会被包装为对象这是书上的一句原话,我的理解就是,在java这个大环境中,就像是流水线工厂一样,代码的编译就是进行流水线作业,代码输进来,开始的时候就是打包封装, ...
- Struts2_ValueStack,OGNL详解(转)
原文地址:http://blog.csdn.net/wyply115/article/details/8257140 一.OGNL表达式 1.ognl是struts2中使用的一种表达式语言,可用于js ...
- jcl-over-slf4j log桥接工具简介
ava 界里有许多实现日志功能的工具,最早得到广泛使用的是 log4j,许多应用程序的日志部分都交给了 log4j,不过作为组件开发者,他们希望自己的组件不要紧紧依赖某一个工具,毕竟在同一个时候还有很 ...
- C指针-const char* p到底是什么不可以改变
char a = 'w'; char b = 'q'; const char* p = &a; p = &b; printf("%c",p[0]); 如上一段代码, ...
- python爬虫beta版之抓取知乎单页面回答(low 逼版)
闲着无聊,逛知乎.发现想找点有意思的回答也不容易,就想说要不写个爬虫帮我把点赞数最多的给我搞下来方便阅读,也许还能做做数据分析(意淫中--) 鉴于之前用python写爬虫,帮运营人员抓取过京东的商品品 ...