この記事で共有した内容は、OC と JS の間の相互作用を実現する方法です。必要な友人はそれを参照できます
oc code
#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 コード内のデータと一致している必要があります。 。
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:// はバックエンドとネゴシエートされたカスタム プロトコル ヘッダーの件名であり、id は JS によって OC に渡される値であり、次のように区切られています。開ける。
関連する推奨事項:
以上がOCとJSの相互作用を実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。