iOS与h5交互
废话不多说直接上干货:
iOS与h5常见的就是原生传值给h5,h5调用原生两种;
第一种(原生传值给h5):
本篇博客则是讲了OC传值给JS,代码似乎更简单。
OC传值给JS的代码:
// 页面加载完成之后调用
- (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation{
[SVProgressHUDdismiss];
NSString * jsStr [NSStringstringWithFormat:@"payResult('%@')",@"true"];
[self.webViewevaluateJavaScript:jsStrcompletionHandler:^(id_Nullable result, NSError * _Nullable error) {
NSLog(@"==%@----%@",result, error);
}];
}
OC给JS传值需要再网页加载完成之后进行,当初我传值给JS的是用户的登录状态,JS需要拿到用户的登录状态去进行收藏的操作。
JS接收OC传值的代码:
function payResult(str){
if(str == ‘ture’){
alert(‘登录’);
}
}
OC代码中的payResult()方法是JS中的方法,里面的参数是传递给JS的数据。注意:JS能接收到OC传递的数据,但却不能进行输出,需要进行判断,看接收到的数据是不是某个数据。当初在做这块的时候iOS这边打印的一直是null,写JS的哥们也一直说没有接收到数据,(他说我的代码有问题,我说他的代码有问题),最后才发现JS接收到的数据不能输出打印,只能进行判断。
再次提醒:这种OC给JS传参数的方式实际就是OC调用JS方法,传的值是JS方法的一个参数。
第二种(h5调用原生并传值):
原理很简单:
监听的方法名要和JS开发的人商量好。这里我们监听的是ShareP方法,对于JS开发的人员必须要以以下方式写。
window.webkit.messageHandlers. ShareP.postMessage(
null
)
2.实现协议方法
[self shareBnt]里面就是我们iOS需要执行的方法。至此OK