首先 iOS7開始 蘋果公佈了JavaScriptCore.framework 它使得JS與OC的交互更加方便了。
第一步:導入framework
OC 調用JS方法 :(一句話即可)
-(void)webViewDidFinishLoad:(UIWebView *)webView
{
// JS url加載完成後,可直接調用JS方法showmessage。 如果有需求,還可以傳遞參數。
[myWebView stringByEvaluatingJavaScriptFromString:@"showmessage('參數')"];
// 若JS有返回值此方法會直接返回。返回的格式爲URL編碼格式,所以必須解碼才能使用。 下邊是解碼方法
例如: NSString *data = [myWebView stringByEvaluatingJavaScriptFromString:@"showmessage('參數')"];
}
// URL 解碼
- (NSString *)decodeFromPercentEscapeString: (NSString *) input
{
NSMutableString *outputStr = [NSMutableString stringWithString:input];
[outputStr replaceOccurrencesOfString:@"+"
withString:@" "
options:NSLiteralSearch
range:NSMakeRange(0, [outputStr length])];
return [outputStr stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
}
JS調用OC方法:
// webView 的代理方法, 網頁加載之前調用。看到之前有同學提供的例子。
首先在js中聲明方法
- <html>
- <head>
- <meta http-equiv="content-type"content="text/html;charset=utf-8">
- <title>js調用oc</title>
- <script type="text/javaScript">
- /* 調用本地帶參數的方法 */
- function testFunction1(cmd,parameter1){
- return document.location="objc://"+cmd+":/"+parameter1; //cmd代表objective-c中的的方法名,parameter1自然就是參數了
- }
- /* 調用本地不帶參數的方法 */
- function testFunction2(cmd){
- return document.location="objc://"+cmd; //cmd代表objective-c中的的方法名
- }
- </script>
- </head>
- <body>
- <p><button type="text" id="text1" value="點擊這裏1"onclick="testFunction1('printLog:','str')">調用本地帶參數的方法</button></p>
- <p><button type="text" id="text2" value="點擊這裏2"onclick="testFunction2('testFunc')">調用本地不帶參數的方法</button></p>
- </body>
- </html>
再調用webview代理
- - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
- {
- NSString *urlString = [[request URL] absoluteString];
- NSArray *urlComps = [urlStringcomponentsSeparatedByString:@"://"];
- if([urlComps count] && [[urlCompsobjectAtIndex:0] isEqualToString:@"objc"])
- {
- NSArray *arrFucnameAndParameter = [(NSString*)[urlCompsobjectAtIndex:1] componentsSeparatedByString:@":/"];
- NSString *funcStr = [arrFucnameAndParameterobjectAtIndex:0];
- if (1 == [arrFucnameAndParametercount])
- {
- // 沒有參數
- if([funcStr isEqualToString:@"testFunc"])
- {
- /*調用本地函數*/
- [self testFunc];
- }
- }
- else if(2 == [arrFucnameAndParametercount])
- {
- //有參數的
- if([funcStr isEqualToString:@"printLog:"] && [arrFucnameAndParameterobjectAtIndex:1])
- {
- /*調用本地函數*/
- [self printLog:@"js調用本地帶參數的方法成功!"];
- }
- }
- return NO;
- };
- return YES;
- }
- - (void)printLog:(NSString *)str
- {
- NSLog(@"%@", str);
- }
- - (void)testFunc
- {
- NSLog(@"js調用本地不帶參數的方法成功!");
- }