< 返回首页

标哥的笔记,是记录在日常学习技术和日常开发中那些年遇到过的坑!本站为新站,原"标哥的技术博客"中的文章会慢慢移到本站,欢迎收藏本站!
在使用本站过程中,有任何建议请联系标哥! 另,承接App开发、网站开发和微信小程序开发!欢迎联系我们


ObjC点击H5图片Native预览

 作者:标哥    发布日期:2017-01-12 12:08    阅读量:749次
 

最近很多朋友看到了我的JS与OC/Swift交互的文章,经常有朋友问HTML中的图片在点击时如何在原生预览?这个问题其实很简单,只是一直没有动手去实践过。今天借着闲时,动手写了个demo,只是实现了点击接收,不实现预览功能,怎么预览就是大家要做的事了。

本篇文章只是说明通过怎样的方式接入,才能让iOS Native与Js交互,当然这里不会使用JavaScriptCore这个库,也不会使用任何第三方,如UIWebViewJavaScriptBridge。

实现代码

实现思路:面对iOS与JS交互,最直接的就是UIWebView的代理方法。那么,提炼出来的问题就是:如何知道H5中的图片被点击了?在点击以后又如何在iOS端判断?针对第一个问题,最直接的方式就是注入图片点击的JS代码。针对第二个问题,最直接的方式就是通过注入特定的scheme来识别:

@implementation ViewController

- (void)viewDidLoad {
  [super viewDidLoad];

  UIWebView *webview = [[UIWebView alloc] initWithFrame:self.view.bounds];
  [self.view addSubview:webview];
  webview.delegate = self;
  
  [webview loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.cocoachina.com/programmer/20160113/14976.html"]]];
}

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
  if ([request.URL.scheme hasPrefix:@"hyb-image-preview"]) {
    // 获取原始图片的完整URL
    NSString *src = [request.URL.absoluteString stringByReplacingOccurrencesOfString:@"hyb-image-preview:" withString:@""];
    if (src.length > 0) {
      // 原生API展开图片
      // 这里已经拿到所点击的图片的URL了,剩下的部分,自己处理了
      // 有时候会感觉点击无响应,这是因为webViewDidFinishLoad,还没有调用。
      // 调用很晚的原因,通常是因为H5页面中有比较多的内容在加载
      // 因此,若是原生APP与H5要交互,H5要尽可能地提高加载速度
      // 不相信?在webViewDidFinishLoad加个断点就知道了
      NSLog(@"所点击的HTML中的img标签的图片的URL为:%@", src);
    }
  }
  return YES;
}

- (void)webViewDidFinishLoad:(UIWebView *)webView {
  NSString *js = @"function addImgClickEvent() { \
                       var imgs = document.getElementsByTagName('img'); \
                       for (var i = 0; i < imgs.length; ++i) { \
                            var img = imgs[i]; \
                            img.onclick = function () { \
                                window.location. target="_blank" rel="nofollow" href = 'hyb-image-preview:' + this.src; \
                            }; \
                        } \
                   }";
  // 注入JS代码
  [webView stringByEvaluatingJavaScriptFromString:js];
  // 执行所注入的JS代码
  [webView stringByEvaluatingJavaScriptFromString:@"addImgClickEvent();"];
}

@end

这里需要到写JS函数,如何JS都不懂,那就不知道怎么办了,当然让后台帮你写也是可以的。这里所实现的功能是非常简单的,只是往H5中注入了JS函数,然后执行所注入的JS函数,给所有的img标签添加上onclick事件处理,在img被点击时,重新载入图片就会回调我们UIWebView的shouldStartLoadWithRequest代理方法,然后在此处识别是否是我们所指定的scheme,如果是,则认为这个是我们要处理的图片预览。

效果图片

标哥的笔记

源代码

请大家到我的GITHUB地址下载吧:HTMLImagePreviewDemo


承接:ThinkPHP项目开发、网站项目开发、微信项目开发、微信小程序项目开发、App开发,欢迎联系标哥QQ632840804