【iOS】OC与JS交互 网页中调用JS与JS注入

很多应用为了节约成本,做出同时在Android与iOS上都能使用的界面,这时就要使用WebView来做。Android和IOS上都有WebView,做起来很省事。当然这时就要考虑如何在Android或iOS中实现与网页的交互。对iOS而言,包括如何在网页中调用OC,以及如何在OC中对网页进行操作。

先将网页弄到iOS项目中:

网页内容如下, 仅供测试:

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <html>  
  2. <head>  
  3.     <meta xmlns="http://www.w3.org/1999/xhtml" http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  4.     <title>这是一个示例html文件</title>  
  5.     <script Type='text/javascript'>  
  6.         function clickme() {  
  7.             alert('点击按钮了!');  
  8.         }  
  9.     </script>  
  10. </head>  
  11. <body>  
  12.     <h1>OC与JS互动</h1>  
  13.     <h2>blog.csdn.net/xn4545945</h2>  
  14.     <!-- 自定义协议与OC进行交互 -->  
  15.     <a href="neng://loadUrl/blog.csdn.net">点击一下, 链接调用OC函数</a>  
  16.     <br/>  
  17.     <br/>  
  18.     <a href="http://m.baidu.com">js注入, 到baidu页面上实验</a>  
  19. </body>  
  20. </html>  

一、在OC中调用JS

最重要的方法:stringByEvaluatingJavaScriptFromString

直接上代码,说明见注释:

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. /**===========================OC 中调用 JS====================================*/  
  2. - (void)webViewDidFinishLoad:(UIWebView *)webView {  
  3.     //1.OC中调用JS的文档对象. (先拼出文档对象的属性) 可以在浏览器控制台输入来进行测试  
  4.     NSLog(@"%@", [self.webView stringByEvaluatingJavaScriptFromString:@"document.title"]);  
  5.   
  6.     //2.OC中调用JS的方法  
  7.     [self.webView stringByEvaluatingJavaScriptFromString:@"clickme()"];  
  8. }  

二、用超链接来调用OC中方法

步骤:

* 1. 设置 webView 的代理 < UIWebViewDelegate >
* 2 . 在代理的方法 shouldStartLoadWithRequest : 中调用 . ( 该方法与网页的加载有关 )
* 方法 : 就是在网页链接中 写好自定义协议 . 然后在 OC 方法中 检查点击的链接 中是否有该协议 , 有则 做相关操作 .
代码如下:

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. /**=========================== webView链接 中调用 OC===============================*/  
  2. /**webView的代理方法:加载页面有关. 当直接返回为NO时,会调用JS方法 
  3.    其中request参数与发送请求有关*/  
  4. - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {  
  5.     NSLog(@"%@", request.URL.absoluteString); //可以直接拿到发送请求的网址  
  6.     NSString *urlStr = request.URL.absoluteString;  
  7.   
  8.     // 格式 neng://loadUrl/blog.csdn.net  协议/方法/网址  
  9.     //判断链接中的协议头,如果是neng://, 则进行相关操作  
  10.     if ([urlStr hasPrefix:@"neng://"]) {  
  11.         //拿到除去协议头的后部  
  12.         NSString *urlContent = [urlStr substringFromIndex:[@"neng://" length]];  
  13.         NSLog(@"%@", urlContent);  
  14.   
  15.         //用/来拆分字符串  
  16.         NSArray *urls = [urlContent componentsSeparatedByString:@"/"];  
  17.         NSLog(@"拆分的结果为:%@", urls);  
  18.   
  19.         //取出方法名  
  20.         if (urls.count != 2) {  
  21.             return NO;  
  22.         }  
  23.         NSString *funName = [NSString stringWithFormat:@"%@:", urls[0]]; //带参数的方法,加冒号  
  24.   
  25.         SEL callFun = NSSelectorFromString(funName);  
  26. //取消警告  
  27. # pragma clang diagnostic push  
  28. # pragma clang diagnostic ignored "-Warc-performSelector-leaks"  
  29.         [self performSelector:callFun withObject:urls[1]]; //将blog.csdn.net作为参数传入  
  30. # pragma clang diagnostic pop  
  31.         NSLog(@"方法名为%@, 传入参数为%@", funName, urls[1]);  
  32.   
  33.         return NO;  
  34.     }  
  35.   
  36.     return YES;  
  37. }  
  38.   
  39. - (void)loadUrl:(NSString *)urlStr {  
  40.     NSLog(@"接收到参数: %@", urlStr);  
  41.   
  42.     //跳转到指定的URL--->urlStr  
  43.     NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"http://%@", urlStr]];  
  44.     NSURLRequest *request = [NSURLRequest requestWithURL:url];  
  45.   
  46.     [self.webView loadRequest:request];  
  47. }  

三、JS实现注入

JS是操作网页的利器,利用好JS才能真正在应用中随心所欲的操作网页。

核心方法:stringByEvaluatingJavaScriptFromString(与第一个相同,这个是在iOS中操作JS最重要方法)

代码如下:

[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. /**===========================JS  注入====================================*/  
  2. - (void)jsClick {  
  3.     [self.webView stringByEvaluatingJavaScriptFromString:@"var script = document.createElement('script');"  
  4.      "script.type = 'text/javascript';"  
  5.      "script.text = \"function myFunction() { "   //定义myFunction方法  
  6.      "var field = document.getElementsByName('word')[0];"  
  7.      "field.value='WWDC2014';"  
  8.      "document.forms[0].submit();"  
  9.      "}\";"  
  10.      "document.getElementsByTagName('head')[0].appendChild(script);"];  //添加到head标签中  
  11.   
  12.     [self.webView stringByEvaluatingJavaScriptFromString:@"myFunction();"];  
  13. }  




附上例子源码:http://download.csdn.net/detail/xn4545945/7584575


转载请注明出处:http://blog.csdn.net/xn4545945  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值