日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

实现OC与JS的交互

發(fā)布時間:2023/12/15 javascript 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 实现OC与JS的交互 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
oc-->js stringByEvaluatingJavaScriptFromString,其參數(shù)是一NSString 字符串內(nèi)容是js代碼(這又可以是一個js函數(shù)、一句js代碼或他們的組合),當(dāng)js函數(shù)有返回值或一句js代碼有值返回可通過stringByEvaluatingJavaScriptFromString的返回值獲取。

js-->oc 利用webView的重定向原理(即重新在js中指定document.location的值,此為一url),只要在這個url字符串中按自定義的規(guī)則指定好所需調(diào)用oc中的函數(shù)和參數(shù),然后通過OC中的shouldStartLoadWithRequest函數(shù)去捕獲處理請求。

?

?
1 2 3 4 5 //APP調(diào)用webView加載的JS中的方法interfaceCalledByAPP,此例傳入了兩個參數(shù) - (void)sendMessage:(id)sender { ????[self.webView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"interfaceCalledByAPP(\"%@\",\"%@\")", @"2",@"333"]]; }

1 2 3 4 //JS向APP傳值。首先實現(xiàn)UIWebView的代理,然后根據(jù)NSURLRequest的URL進(jìn)行不同處理 //JS中的將要傳遞的數(shù)據(jù)作為URL重定向 var tempurl = "將要傳遞的值"; window.location.href= encodeURI(encodeURI(tempurl));

?

?

?
1 2 3 4 5 6 7 8 9 10 11 //webView的代理相應(yīng)重定向 - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{ ????NSString *requestString = [[[request URL]? absoluteString] stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; ????NSLog(@"should-------"); ????if ([requestString hasPrefix:@"url://"]) { ????????//根據(jù)自己定義的規(guī)則,通過字符串的值,調(diào)用OC的方法。這里就輸出一下字符串了。 ????????NSLog(@"===%@",requestString); ????} ????return YES; }


?

總結(jié)

以上是生活随笔為你收集整理的实现OC与JS的交互的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。