转载自:http://www.devzeng.com/blog/ios-uiwebview-interaction-with-javascript.htmljavascript
还可参考的文章:http://blog.csdn.net/lwjok2007/article/details/47058101html
在iOS开发中不少时候咱们会和UIWebView打交道,目前国内的不少应用都采用了UIWebView的混合编程技术,最多见的是微信公众号的内容页面。前段时间在作微信公众平台相关的开发,发现不少应用场景都是利用HTML5和UIWebView来实现的。java
Objective-C语言调用JavaScript语言,是经过UIWebView的 - (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;
的方法来实现的。该方法向UIWebView传递一段须要执行的JavaScript代码最后获取执行结果。ios
JavaScript语言调用Objective-C语言,并无现成的API,可是有些方法能够达到相应的效果。具体是利用UIWebView的特性:在UIWebView的内发起的全部网络请求,均可以经过delegate函数获得通知。git
下面提供一个简单的例子介绍如何相互的调用,实现的效果是在界面上点击一个连接,而后弹出一个对话框判断是否登陆成功。github
(1)示例的HTML的源码以下:web
1
2 3 4 5 6 7 8 9 10 11 12 |
<html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=Edge" /> <meta content="always" name="referrer" /> <title>测试网页</title> </head> <body> <br /> <a href="devzeng://login?name=zengjing&password=123456">点击连接</a> </body> </html> |
(2)UIWebView Delegate回调方法为:编程
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType { NSURL *url = [request URL]; if([[url scheme] isEqualToString:@"devzeng"]) { //处理JavaScript和Objective-C交互 if([[url host] isEqualToString:@"login"]) { //获取URL上面的参数 NSDictionary *params = [self getParams:[url query]]; BOOL status = [self login:[params objectForKey:@"name"] password:[params objectForKey:@"password"]]; if(status) { //调用JS回调 [webView stringByEvaluatingJavaScriptFromString:@"alert('登陆成功!')"]; } else { [webView stringByEvaluatingJavaScriptFromString:@"alert('登陆失败!')"]; } } return NO; } return YES; } |
说明:微信
一、同步和异步的问题网络
(1)Objective-C调用JavaScript代码的时候是同步的
- (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;
(2)JavaScript调用Objective-C代码的时候是异步的
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
二、常见的JS调用
(1)获取页面title
NSString *title = [webview stringByEvaluatingJavaScriptFromString:@"document.title"];
(2)获取当前的URL
NSString *url = [webview stringByEvaluatingJavaScriptFromString:@"document.location.href"];
三、使用第三方库
https://github.com/marcuswestin/WebViewJavascriptBridge
一、动态将网页上的图片所有缩放
JavaScript脚本以下:
1
2 3 4 5 6 7 8 9 10 11 12 |
function ResizeImages() { var myImg, oldWidth; var maxWidth = 320; for(i = 0; i < document.images.length; i++) { myImg = document.images[i]; if(myImg.width > maxWidth) { oldWidth = myImg.width; myImg.width = maxWidth; myImg.heith = myImg.height*(maxWidth/oldWidth); } } } |
在iOS代码中添加以下代码:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
[webView stringByEvaluatingJavaScriptFromString: @"var script = document.createElement('script');" "script.type = 'text/javascript';" "script.text = \"function ResizeImages() { " "var myimg,oldwidth;" "var maxwidth=380;" //缩放系数 "for(i=0;i <document.images.length;i++){" "myimg = document.images[i];" "if(myimg.width > maxwidth){" "oldwidth = myimg.width;" "myimg.width = maxwidth;" "myimg.height = myimg.height * (maxwidth/oldwidth);" "}" "}" "}\";" "document.getElementsByTagName('head')[0].appendChild(script);"]; [webView stringByEvaluatingJavaScriptFromString:@"ResizeImages();"]; |