首頁 > web前端 > js教程 > 如何實現OC與JS的交互

如何實現OC與JS的交互

零到壹度
發布: 2018-04-13 16:44:34
原創
1739 人瀏覽過

本篇文章給大家分享的內容是如何實現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的相互互動

##OC與JS互動

以上是如何實現OC與JS的交互的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板