js和oc相互交互

从oc到js:

UIWebView与javascript交互的方法就是stringByEvaluatingJavaScriptFromString:

有了这个方法我们可以通过objc调用javascript,可以注入javascript。

首先我们来看一下,如何调用javascript:

[webView stringByEvaluatingJavaScriptFromString:@"myFunction();"]; 
这儿myFunction()就是我们的javascript方法。

再来看看入何注入javascript,我们先写一个需要注入的javascript:

 function showAlert()  

   alert('in show alert');  

}  

保存为test.js,然后拖到xcode的resource分组下。再用代码在初始化的时候注入这个js(如在viewDidLoad方法里)。

NSString *filePath [[NSBundle mainBundle] pathForResource:@"test" ofType:@"js"];  

NSString *jsString [[NSString alloc] initWithContentsOfFile:filePath];  

[webView stringByEvaluatingJavaScriptFromString:jsString];  

这样就注入了上面的js,那么我们可以随时调用js的方法

从js到oc:

原理就是利用UIWebView重定向请求,传一些命令到我们的UIWebView,在UIWebView的delegate的方法中接收这些命令,并根据命令执行相应的objc方法。这样就相当于在javascript中调用objc的方法。说起来有点抽象,看看代码一下就明白。

首先我们写一个javascript 方法如下:

[javascript] 
function  sendCommand(cmd,param){  
        var  url= "testapp:" +cmd+ ":" +param;  
        document.location  url;   
 
function  clickLink(){  
        sendCommand( "alert" , "你好吗?" );  
}  

然后在你的html里调用这个js方法如: 
[javascript] 
"button"  value= "Click me!"  onclick= "clickLink()"  />

最后我们在UIWebVew中截获这个重定向请求:

#pragma mark --    
#pragma mark UIWebViewDelegate    
   
( BOOL )webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType  
            NSString  *requestString  [[request  URL]  absoluteString];   
NSArray *components [requestString componentsSeparatedByString:@ ":" ];  
  if  ([components count] && [(NSString *)[components objectAtIndex:0] isEqualToString:@ "testapp" ])  
    if ([(NSString *)[components objectAtIndex:1] isEqualToString:@ "alert" ])   
       
        UIAlertView  *alert  [[UIAlertView  alloc]     
                                 initWithTitle:@ "Alert from Cocoa Touch"  message:[components objectAtIndex:2]  
                                                                  delegate:self  cancelButtonTitle:nil   
                                 otherButtonTitles:@ "OK" nil];  
                    [alert  show];   
             
        return  NO; 
         
     return  YES;  
}  


 不过有一个开源工程大家可以看看,它允许javascript调用objective_c的方法。叫

jsbridge-to-cocoa  http://code.google.com/p/jsbridge-to-cocoa/

还有两个相关工程

WebViewJavascriptBridge 与 GAJavaScript 值得大家慢慢研究。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值