WebView加载H5页面

1.向后台服务器请求数据

-(void)viewDidLoad
{
    [super viewDidLoad];
    self.title = self.headline.title;
    
    self.automaticallyAdjustsScrollViewInsets = NO;
//    [self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:self.headline.url_3w]]];
    
    NSString *url = [NSString stringWithFormat:@"http://c.m.163.com/nc/article/%@/full.html",self.headline.docid];
    [[LTHttpManager manager] GET:url parameters:nil progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
//        [responseObject writeToFile:@"/Users/xiufengfan/Desktop/detail.plist" atomically:YES];
//        NSLog(@"%@",self.headline.docid);
        LTNewsDetail *detail = [LTNewsDetail mj_objectWithKeyValues:responseObject[self.headline.docid]];
        self.detail = detail;
        [self showNewsDetail];
    } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
        
    }];
    
}
  1. 初始化html,并显示
-(void)showNewsDetail
{
    /*
    NSMutableString *html = [NSMutableString string];
    // 头内容
    [html appendString:@"<html>"];
    [html appendString:@"<head>"];
    [html appendFormat:@"<link rel=\"stylesheet\" href=\"%@\">",[[NSBundle mainBundle] URLForResource:@"LTNewsDetail.css" withExtension:nil]];
    [html appendString:@"</head>"];
    // 具体内容
    [html appendString:@"<body>"];
    
    // 将图片插入body对应的标记中,比如<!--IMG#0-->
    [html appendString:[self setupBody]];
    
    [html appendString:@"</body>"];
    // 尾部内容
    [html appendString:@"</html>"];
     */
    NSMutableString *html = [NSMutableString stringWithContentsOfURL:[[NSBundle mainBundle] URLForResource:@"LTNewsDetail.tpl" withExtension:nil] encoding:NSUTF8StringEncoding error:nil];
    
    NSString *link = [NSString stringWithFormat:@"%@",[[NSBundle mainBundle] URLForResource:@"LTNewsDetail.css" withExtension:nil]];
    
    [html replaceOccurrencesOfString:@"<!--LINKHREF-->" withString:link options:NSCaseInsensitiveSearch range:NSMakeRange(0, html.length)];
    // 将图片插入body对应的标记中,比如<!--IMG#0-->
    [html replaceOccurrencesOfString:@"<!--BODY-->" withString:[self setupBody] options:NSCaseInsensitiveSearch range:NSMakeRange(0, html.length)];
    
    // 显示网页
    [self.webView loadHTMLString:html baseURL:nil];
}

3.初始化body,并返回body

-(NSString*)setupBody
{
    /*
    // 手动添加标签
    NSMutableString *body = [NSMutableString string];
    // 拼接标题
    [body appendFormat:@"<div class = \"title\">%@</div>",self.detail.title];
    // 拼接时间
    [body appendFormat:@"<div class = \"time\">%@</div>",self.detail.ptime];
    // 拼接内容
    [body appendString:self.detail.body];
    */
    
    // 利用模板添加标签
    NSMutableString *body = [NSMutableString stringWithContentsOfURL:[[NSBundle mainBundle] URLForResource:@"LTNewsDetailBody.tpl" withExtension:nil] encoding:NSUTF8StringEncoding error:nil];
    [body replaceOccurrencesOfString:@"<!--DIVTITLE-->" withString:self.detail.title options:NSCaseInsensitiveSearch range:NSMakeRange(0, body.length)];
    [body replaceOccurrencesOfString:@"<!--DIVTIME-->" withString:self.detail.ptime options:NSCaseInsensitiveSearch range:NSMakeRange(0, body.length)];
    [body appendString:self.detail.body];
    
    // 拼接图片
    for (LTNewsDetailImg *img in self.detail.img) {
        // 图片html的字符串
        NSMutableString *imgHtml = [NSMutableString stringWithContentsOfURL:[[NSBundle mainBundle]URLForResource:@"LTNewsDetailBodyImg.tpl" withExtension:nil] encoding:NSUTF8StringEncoding error:nil];
        /*
         // 手动添加标签
        [imgHtml appendString:@"<div class = \"img-parent\">"];
        NSString *onload = @"this.onclick = function(){ window.location.href = 'lt:src=' + this.src;}";
        NSString *imgStr = [NSString stringWithFormat:@"<img onload =\"%@\" width = \"%d\" height = \"%d\" src=\"%@\">",onload,img.imgWidth,img.imgHeight,img.src];
        [imgHtml appendString:@"</div>"];
        */
        // 利用模板添加标签
        [imgHtml replaceOccurrencesOfString:@"<!--IMGWIDTH-->" withString:[NSString stringWithFormat:@"%d",img.imgWidth] options:NSCaseInsensitiveSearch range:NSMakeRange(0, imgHtml.length)];
        [imgHtml replaceOccurrencesOfString:@"<!--IMGHEIGHT-->" withString:[NSString stringWithFormat:@"%d",img.imgHeight] options:NSCaseInsensitiveSearch range:NSMakeRange(0, imgHtml.length)];
        [imgHtml replaceOccurrencesOfString:@"<!--IMGSRC-->" withString:[NSString stringWithFormat:@"%@",img.src] options:NSCaseInsensitiveSearch range:NSMakeRange(0, imgHtml.length)];
        
        // 为图片添加需要被拦截的href
        NSString *href = @"'lt:(saveImageToAlbum:)&src=' + this.src";
        self.href = href;
        [imgHtml replaceOccurrencesOfString:@"<!--ONLOADHREF-->" withString:self.href options:NSCaseInsensitiveSearch range:NSMakeRange(0, imgHtml.length)];
        
        // 将img.ref替换为img标签内容
        [body replaceOccurrencesOfString:img.ref withString:imgHtml options:NSCaseInsensitiveSearch range:NSMakeRange(0, body.length)];
    }
    return body;
}
  1. 在h5界面要使用原生功能时,需要监听webView的代理,使用h5 脚本语言加载 href 时调用webView的开始加载请求时调用代理方法webView:(UIWebView *)webView shouldStartLoadWithRequest:navigationType:,可以判断请求是否需要拦截.
// MARK: pragma mark - UIWebViewDelegate
-(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
    NSString *url = request.URL.absoluteString;
    NSRange range = [url rangeOfString:@"lt:(saveImageToAlbum:)&src="];
    if (range.location != NSNotFound) {
        NSUInteger loc = range.location  + range.length;
        NSString *src = [url substringFromIndex:loc];
        // 执行协议method(saveImageToAlbum:)
        NSRange firstRange = [url rangeOfString:@"("];
    
        NSRange lastRange = [url rangeOfString:@":)"];
        
        NSRange methodRange = NSMakeRange(firstRange.location+firstRange.length, lastRange.location - firstRange.location);
    
        NSString *methodStr = [url substringWithRange:methodRange];
        
        [self performSelector:NSSelectorFromString(methodStr) withObject:src afterDelay:0];
        return NO;
    }
    return YES;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 最近遇到 webview 加载一个h5页面,根本无法加载,打开即崩溃,后来检查 原来是一个css属性不支持,属性如...
    三丰张阅读 2,413评论 1 3
  • iOS开发系列--网络开发 概览 大部分应用程序都或多或少会牵扯到网络开发,例如说新浪微博、微信等,这些应用本身可...
    lichengjin阅读 3,707评论 2 7
  • 首页(新闻数据的处理) 后台返回的数据只有一个Html的Body内容。至于文本的显示样式需要在本地拼处理 这时候就...
    0诛仙0阅读 665评论 0 7
  • 1、设置UILabel行间距 NSMutableAttributedString* attrString = [[...
    十年一品温如言1008阅读 1,694评论 0 3
  • 专注懂事二十年的好孩子,专注懂事二十年的好傻子。 初始是带着启蒙的意味,如光荣纯洁的使命:“以后要做一个懂事的孩子...
    明治阅读 490评论 0 1