如何实现OC与JS的交互
程序员文章站
2022-05-03 17:37:59
...
本篇文章给大家分享的内容是如何实现OC与JS的交互,有着一定的参考价值,有需要的朋友可以参考一下
第一种:JS给OC传值,使用JavaScriptCore.framework。
oc 代码
#import <JavaScriptCore/JavaScriptCore.h>
- (void) webViewDidFinishLoad:(UIWebView *)webView{ JSContext *context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]; context[@"favQues"] = ^{ NSArray *a = [JSContext currentArguments]; for (id obj in a) { NSLog(@"obj:%@",obj); } }; }
其中 favQues 是 JS 中返回数据的函数,obj 就是 JS 传给 OC 的值。
JS 代码
function QMAction(id, subject, el) { favQues(id,subject,el); }
其中 QMAction 是HTML中的方法,id、subject,el是传进去的参数,favQues 是返回数据的函数,必须与 OC 代码中的保持一致。
第二种:JS给OC传值,使用自定义URL方法。
OC 代码
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{ NSString *requestUrlStr = [[request.URL absoluteString] stringByRemovingPercentEncoding]; if ([requestUrlStr hasPrefix:@"objc://"]) { NSArray *a = [requestUrlStr componentsSeparatedByString:@"://"]; NSString *paramStr = a[1]; NSArray *a1 = [paramStr componentsSeparatedByString:@":/"]; if (a1.count > 0) { NSLog(@"%@-%@",a1[1],a1[2]); }else{ NSLog(@"没有参数"); } return NO; } return YES; }
JS 代码
function QMAction(at, id, subject, el) { window.location.href="objc://"+":/"+subject+":/"+id; }
其中 objc:// 是与后台商量好的自定义协议头 subject 和 id 是 JS 传给 OC 的值,通过 :/ 隔开。
相关推荐:
以上就是如何实现OC与JS的交互的详细内容,更多请关注其它相关文章!
上一篇: MySQL查看日志_MySQL
下一篇: php set
推荐阅读
-
Android编程使用WebView实现与Javascript交互的方法【相互调用参数、传值】
-
Android App端与PHP Web端的简单数据交互实现示例
-
PHP与javascript实现变量交互的示例代码
-
JS实现页面跳转与刷新的方法汇总
-
Cwrsync如何使用可以实现Linux与windows下的文件同步详解
-
Activity与Service之间交互并播放歌曲的实现代码
-
Android的WebView与H5前端JS代码交互的实例代码
-
JS与OC交互,JS中调用OC方法(获取JSContext的方式)
-
JS实现生成由字母与数字组合的随机字符串功能详解
-
JS实现的汉字与Unicode码相互转化功能分析