如何实现OC与JS的交互

零到壹度
Lepaskan: 2018-04-13 16:44:34
asal
1664 orang telah melayarinya

本篇文章给大家分享的内容是如何实现OC与JS的交互,有着一定的参考价值,有需要的朋友可以参考一下

第一种:JS给OC传值,使用JavaScriptCore.framework。

oc 代码

#import <JavaScriptCore/JavaScriptCore.h>
Salin selepas log masuk
- (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);
        }
    };
}
Salin selepas log masuk

其中 favQues 是 JS 中返回数据的函数,obj 就是 JS 传给 OC 的值。

JS 代码

function QMAction(id, subject, el) {
    favQues(id,subject,el);
}
Salin selepas log masuk

其中 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;
}
Salin selepas log masuk

JS 代码

function QMAction(at, id, subject, el) {
    window.location.href="objc://"+":/"+subject+":/"+id;
}
Salin selepas log masuk

其中 objc:// 是与后台商量好的自定义协议头 subject 和 id 是 JS 传给 OC 的值,通过 :/ 隔开。

相关推荐:

OC与JS的相互交互

OC与JS交互

Atas ialah kandungan terperinci 如何实现OC与JS的交互. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan