iOS js交互(OC)

1.先加载html文件

NSString *mainBundleDirectory=[[NSBundle mainBundle] bundlePath];
        
NSString *path=[mainBundleDirectory stringByAppendingPathComponent:docName]; //docName是html的名字如@"aa.html"
        
NSURL *url=[NSURL fileURLWithPath:path];
        
request=[NSURLRequest requestWithURL:url];

[self.webView loadRequest:request];


2.OC代码调用js方法

    a->将数据转换成能传给js的字符串

NSData *jsonData = [NSJSONSerialization dataWithJSONObject:object
                                                       options:NSJSONWritingPrettyPrinted 
                                                         error:&error];
_content = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
    b->调用js的方法

[_webView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"initA(%@,1)",_content]];  //initA是JS中的方法

3.js调用OC方法
    在UIWebViewDelegate的方法

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
    中写,被js调用的方法,应为每次加载请求的时候都会调用这个方法
NSString *requestString = [[request URL] absoluteString]; //获取请求的链接地址

//当js中调用downloaddata://请求时掉用系统方法
if([requestString hasPrefix:@"downloaddata://"]){
    //调用OC的方法
}


4.点击网页上的图片放大

    在UIWebViewDelegate的方法

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;
    中写,被js调用的方法,应为每次加载请求的时候都会调用这个方法

    //@"image-Prefix:http://。。。"]];//点击图片后js返回的地址
    
    
    if ([request.URL.scheme isEqualToString:@"image-Prefix"]) {
        NSString* path = [request.URL.absoluteString substringFromIndex:[@"image-image-Prefix:" length]];
        path = [path stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
        
        //path就是图片的链接,可以进行相关操作
        
        return NO;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值