html代码处理(如图片、字体大小)

2018-01-30  本文已影响96人  番薯大佬

对于html源码的处理,我是写在一个NSString的类别中。

过滤html源码中的图片

- (NSArray *)htmlStringFilterImages
{
    NSMutableArray *resultArray = [NSMutableArray array];
    if (self && 0 < self.length)
    {
        NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"<(img|IMG)(.*?)(/>|></img>|>)" options:NSRegularExpressionAllowCommentsAndWhitespace error:nil];
        NSArray *result = [regex matchesInString:self options:NSMatchingReportCompletion range:NSMakeRange(0, self.length)];
        
        for (NSTextCheckingResult *item in result)
        {
            NSRange range = [item rangeAtIndex:0];
            NSString *imgHtml = [self substringWithRange:range];
            NSArray *tmpArray = nil;
            if ([imgHtml rangeOfString:@"src=\""].location != NSNotFound)
            {
                tmpArray = [imgHtml componentsSeparatedByString:@"src=\""];
            }
            else if ([imgHtml rangeOfString:@"src="].location != NSNotFound)
            {
                tmpArray = [imgHtml componentsSeparatedByString:@"src="];
            }
            
            for (NSString *image in tmpArray)
            {
                if ([image hasPrefix:@"https://"] || [image hasPrefix:@"http://"])
                {
                    NSRange range = [image rangeOfString:@".jpg"];
                    if (range.location == NSNotFound)
                    {
                        range = [image rangeOfString:@".png"];
                    }
                    if (range.location != NSNotFound)
                    {
                        NSString *url = [image substringToIndex:(range.location + range.length)];
                        [resultArray addObject:url];
                    }
                }
            }
        }
    }
    return resultArray;
}

html源码中的图片大小处理(JS)

/// 修改html中图片大小的js代码
- (NSString *)htmlStringJSImageSizeWidth:(float)width
{
    return [NSString stringWithFormat:@"var script = document.createElement('script');script.type = 'text/javascript';script.text = \"function ResizeImages() { var imgs = document.getElementsByTagName('img');for (var i = 0; i < imgs.length; i ++) {var img = imgs[i];img.style.width = %@ ;img.style.height = null;}}\";document.getElementsByTagName('head')[0].appendChild(script);", @(width)];
}

html源码中图片大小自适应屏幕大小(非JS)

- (NSString *)htmlStringImageAutoSize
{
    NSString *content = self;
    if (content && 0 < content.length)
    {
        content = [content stringByReplacingOccurrencesOfString:@"<html>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</html>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"<head>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</head>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</body>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</body>" withString:@""];
        content = [NSString stringWithFormat:@"<html> <head> </head> <body> <script type='text/javascript'> window.onload = function(){ var $img = document.getElementsByTagName('img'); for(var p in  $img){ $img[p].style.width = '100%%'; $img[p].style.height ='auto' } } </script>%@</body> </html>",content];
    }
    return content;
}

修改html源码中的字符字体大小

- (NSString *)htmlStringFontSize:(int)fontsize
{
    NSString *content = self;
    if (content && 0 < content.length)
    {
        content = [content stringByReplacingOccurrencesOfString:@"<html>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</html>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"<head>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</head>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</body>" withString:@""];
        content = [content stringByReplacingOccurrencesOfString:@"</body>" withString:@""];
        content = [NSString stringWithFormat:@"<html> <head> <style type=\"text/css\"> body {margin:10;font-size: %@;} </style> </head> <body>%@</body> </html>", (self.htmlContantImage ? @(fontsize) : @(fontsize * 1.5)), content];
    }
    return content;
}
上一篇下一篇

猜你喜欢

热点阅读