webview与html5交互ios,iOS webView与H5页面交互

如今app中H5页面越来越多,app如何与H5页面交互是开发者不可避免的问题,今天就和大家探讨这个问题。

示例网页源码:

webView与H5交互方法

function alertTest()

{

alert("网页提示框!");

}

function postString(){

return document.getElementById("text1").value;

}

打开相册

打开相机

一、借助于第三方

推荐一个比较好的第三方库即:WebViewJavascriptBridge

该库使用起来非常简单:

1.[WebViewJavascriptBridge enableLogging]; // 开启日志

2.//初始化WebViewJavascriptBridge方法

_bridge= [WebViewJavascriptBridge bridgeForWebView:self.webView webViewDelegate:self handler:^(id data,WVJBResponseCallback responseCallback) {

}];

3.JS调用OC方法 //原生与JS约定接口名为“openMyCamera”,data是JS传递过来的信息,responseCallback来将信息传递给JS

[_bridge registerHandler:@"openMyCamera" handler:^(id data,WVJBResponseCallback responseCallback) {

[self openMyCamera];

responseCallback("postInfomationToJS")

}];

4.OC调用JS方法 data传入参数,response返回参数

[_bridge callHandler:@"postString" data:nil responseCallback:^(id response) {

NSLog(@"paySuccessJavascriptHandler responded: %@", response);

}];

深入了解的可以看这篇文章

二、不借助于第三方

1.OC调用JS方法

如上实例代码调用JS的 alertTest与postString方法:

NSString *str = [_webView stringByEvaluatingJavaScriptFromString:@"postString();"];

[_webView stringByEvaluatingJavaScriptFromString:@"alertTest();"];

2.H5页面调用OC方法

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType

webview每次加载之前都会调用这个方法,在此方法中拦截网页加载的URL 我们可以与网页制定协议,例如:以 iOS://开头的URL我们就拦截,再根据拦截信息调用对应的方法。

打开相册

打开相机

这样就可以调用OC的方法了。

- (void)openMyAlbum {

//打开相册

}

- (void)openMyCamera {

//打开相机

}

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {

//在此方法中拦截网页加载的URL 我们可以与网页制定协议,例如:以iOS://开头的URL我们就拦截,再根据拦截信息调用对应的方法

NSString *urlstr = request.URL.absoluteString;

NSRange range = [urlstr rangeOfString:@"ios://"];

if (range.length!=0) {

NSString *method = [urlstr substringFromIndex:(range.location+range.length)];

SEL selctor = NSSelectorFromString(method);

[self performSelector:selctor withObject:nil];

}

return YES;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值