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

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

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

示例Demo下载地址:html

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

环境信息:java

Mac OS X 10.10.1git

Xcode 6.1.1github

iOS 8.1web

 

正文:app

首先看下原图编辑器

原图大小

原图大小

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

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

1、图片自适应

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

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

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

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

效果图:

每张图都一样的宽度

每张图都一样的宽度

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

<head><style>img{max-width: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  maxwidth){" "myimg.width = maxwidth;" "}" "}" "}\";" "document.getElementsByTagName('head')[0].appendChild(script);"]; [webView stringByEvaluatingJavaScriptFromString:@"ResizeImages();"]; } 

2、文章内容自动换行

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

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

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

相关文章
相关标签/搜索