首页 > 代码库 > 实现OC与JS的交互
实现OC与JS的交互
oc-->js stringByEvaluatingJavaScriptFromString,其参数是一NSString 字符串内容是js代码(这又可以是一个js函数、一句js代码或他们的组合),当js函数有返回值或一句js代码有值返回可通过stringByEvaluatingJavaScriptFromString的返回值获取。
js-->oc 利用webView的重定向原理(即重新在js中指定document.location的值,此为一url),只要在这个url字符串中按自定义的规则指定好所需调用oc中的函数和参数,然后通过OC中的shouldStartLoadWithRequest函数去捕获处理请求。
//APP调用webView加载的JS中的方法interfaceCalledByAPP,此例传入了两个参数 - (void)sendMessage:(id)sender { [self.webView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"interfaceCalledByAPP(\"%@\",\"%@\")", @"2",@"333"]]; }
//JS向APP传值。首先实现UIWebView的代理,然后根据NSURLRequest的URL进行不同处理 //JS中的将要传递的数据作为URL重定向 var tempurl = "将要传递的值"; window.location.href= http://www.mamicode.com/encodeURI(encodeURI(tempurl));>//webView的代理相应重定向 - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{ NSString *requestString = [[[request URL] absoluteString] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; NSLog(@"should-------"); if ([requestString hasPrefix:@"url://"]) { //根据自己定义的规则,通过字符串的值,调用OC的方法。这里就输出一下字符串了。 NSLog(@"===%@",requestString); } return YES; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。