zoukankan      html  css  js  c++  java
  • WebView加载HTML图片大小自适应与文章自动换行

    http://www.brighttj.com/ios/ios-webview-load-html-image-adaptive.html

    在很多App中都会使用到webview,尤其是在加载新闻内容等文章形式的数据时。因为图文混编以及不同字体格式的显示,在iOS进行编辑和显示都是一大问题(当然,iOS中也可以用CoreText进行绘制),但是对于web端来说,一个富文本编辑器就可以完美解决这个问题。所以后台很多时候会直接返回HTML代码拿给前端解析,这时,在客户端对HTML代码的处理就显得尤为重要了。

    本文将讲解在webview加载HTML代码时,经常会遇到的图片自适应大小与文章内容自动换行问题。

    示例Demo下载地址:

    https://github.com/saitjr/WebViewLoadHTMLImageAdaptiveDemo.git

    环境信息:

    Mac OS X 10.10.1

    Xcode 6.1.1

    iOS 8.1

    正文:

    首先看下原图

    原图大小

    原图大小

    在HTML代码中设置内容样式,一般使用css或者js,那么根据加载优先级以及加载效果,可以自行选择。

    • js在页面加载完之后加载,所以设置图片样式的时候,会先加载大图,然后突然变小;
    • css在引入时加载,直接加载缩小的图片(实际占用内存不会缩小);

    一、图片自适应

    1. 使用css进行图片的自适应

    在web前端,也就是HTML中,如果只设置图片的宽度,那么高度会根据图片原本尺寸进行缩放。

    如果后台返回的HTML代码中,不包含<head>标签,则可以直接在HTML字符串前加上一下面的代码(如果包含<head>,则在<head>标签内部添加)。代码含义是,不管用户以前设置的图片尺寸是多大,都缩放到宽度为320px大小。

    
    <head><style>img{320px !important;}</style></head>
    
    

    效果图:

    每张图都同样的宽度

    每张图都同样的宽度

    若需要根据图片原本大小,宽度小于320px的不缩放,大于320px的缩小到320px,那么在HTML字符串前加上一下代码:

    
    <head><style>img{max-320px !important;}</style></head>
    
    

    效果图:

    超出设定范围进行缩放

    超出设定范围进行缩放

    2. 使用js进行图片的自适应

    在webview的代理中,执行js代码。(下面这段代码是必须有<head>标签的)

    如果没有<head>标签,也很简单,只需要给返回的HTML字符串前面拼接一个<head></head>即可。

    
    - (void)webViewDidFinishLoad:(UIWebView *)webView
     {
        [webView stringByEvaluatingJavaScriptFromString:
         @"var script = document.createElement('script');"
         "script.type = 'text/javascript';"
         "script.text = "function ResizeImages() { "
             "var myimg,oldwidth,oldheight;"
             "var maxwidth=320;"// 图片宽度
             "for(i=0;i <document.images.length;i++){" "myimg="document.images[i];" "="" "if(myimg.width=""> maxwidth){"
                     "myimg.width = maxwidth;"
                 "}"
             "}"
         "}";"
         "document.getElementsByTagName('head')[0].appendChild(script);"];
        [webView stringByEvaluatingJavaScriptFromString:@"ResizeImages();"];
    }
    
    

    二、文章内容自动换行

    文章的自动换行也是通过css实现的,书写方式图片缩放类似。在没有<body>标签的情况下,在HTML代码前,直接拼接以下代码即可(若包含<body>,则将代码添加到body标签内部),意思是全部内容自动换行。

    
    <body width=320px style="word-wrap:break-word; font-family:Arial">
    
    

    到这里,最基本的图片自适应与文章自动换行就结束了,这其中还会引申出很多实用的技术,例如iOS8中的WKWebView、JSBinding、CommonJS、iOS端使用HTML模板引擎等,我也会在接下来的文章中,一一介绍。

     

    6 Responses to “【iOS】WebView加载HTML图片大小自适应与文章自动换行”

      1. MainasuK

        终于找到解决方法了,感谢。
        不过,脚本中间掉东西了哦,从中间的 for 开始
        你看~
        “var script = document.createElement(‘script’);”
        “script.type = ‘text/javascript’;”
        “script.text = ”function ResizeImages() { ”
        “var myimg,oldwidth,oldheight;”
        “var maxwidth=320;”// 图片宽度
        “for(i=0;i maxwidth){”
        “myimg.width = maxwidth;”
        “}”
        “}”
        “}”;”
        “document.getElementsByTagName(‘head’)[0].appendChild(script);”

  • 相关阅读:
    C++——并发编程
    Poco C++——JSON解析
    #转载#我给所有新手程序员的建议
    #笔记# 如何阅读技术类书籍
    笔记:CSS hack的学习与了解…
    【笔记】CSS选择器整理(IE低版本支持性测试)
    呼吸灯效果
    ajax跨域问题-----jsonp
    【转】js里的时间函数集
    grunt与requirejs结合使用
  • 原文地址:https://www.cnblogs.com/xuejinhui/p/5037031.html
Copyright © 2011-2022 走看看