首页 > 编程语言 > 详细

UIWebView 获取当前的javascript上下文,并js,oc互调

时间:2014-05-23 09:24:23      阅读:480      评论:0      收藏:0      [点我收藏+]

OC调用UIWebView 中的js,网上例子很多,最常用的是UIWebView自带的一个方法;

- (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;

 

UIWebView 中的js 掉用本地的oc方法;

通过UIWebView开始加载请求的代理方法中,去解析OC跟js约定好的协议(比如约定协议objtc://)

比如<a href="objtc://function">调用oc</a>

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{

  NSString *urlString = [[request URL] absoluteString];

  if( [urlString hasPrefix:@"objtc://"] ){

    //调用oc本地方法

    NSLog(@"....");

  }

}

 

第二种方法,比如OC类A中有个UIWebView,UIWebView的js想调用OC类A中的方法,

对于JSContext,JSValue跟OC对象的相互转换,获取js的window文档树,或者其他交互功能,百度很多

1)新建一个协议继承JSExport

#import <JavaScriptCore/JavaScriptCore.h>

#import "objc/runtime.h"

 

@protocol LLCExport <JSExport>

//UIWebView中的js,就可以通过appPushPageTitle(url,title)调用此协议的这个方法

-(void)appPushPage:(NSString*)url title:(NSString*)title;

@end

2)获取类A 的当前UIWebView中的上下文对象JSContext,

self.jsc = [self.webViewvalueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];

3)类A 实现 LLCExport中的方法

-(void)appPushPage:(NSString*)url title:(NSString*)title{

    UIViewController *pvc = [[UIViewController alloc] init];

    pvc.title = title;

    pvc.strUrl = url;

    [self.navigationController pushViewController:pvc animated:YES];

}

4)当UIWebView加载完毕后,给类A动态加自定义的LLCExport协议,然后把类A对象赋值给JSContext中自定义的“APP_NATIVE”对象

- (void)webViewDidFinishLoad:(UIWebView *)webView{

  class_addProtocol(self.class,@protocol(LLCExport));

  self.jsc["APP_NATIVE"] = self;

}

5)js里面就可以通过window.APP_NATIVE.appPushPageTitle("http://www.baidu.com","百度");

来调用OC类A中的-(void)appPushPage:(NSString*)url title:(NSString*)title;这个方法了

 

UIWebView 获取当前的javascript上下文,并js,oc互调,布布扣,bubuko.com

UIWebView 获取当前的javascript上下文,并js,oc互调

原文:http://www.cnblogs.com/loganv/p/3737921.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!