iOS开发——WebView加载HTML图片大小自适应与文章自动换行
2016-06-07 10:48
519 查看
本文主要讲述了如何在iOS应用中使用WebView加载HTML图片时实现自适应与文章自动换行功能,现在把相关的实现思路和代码整理出来分享给iOS程序员兄弟们,希望给他们的开发工作带来帮助。
在很多App中都会使用到webview,尤其是在加载新闻内容等文章形式的数据时。因为图文混编以及不同字体格式的显示,在iOS进行编辑和显示都是一大问题(当然,iOS中也可以用CoreText进行绘制),但是对于web端来说,一个富文本编辑器就可以完美解决这个问题。所以后台很多时候会直接返回HTML代码拿给前端解析,这时,在客户端对HTML代码的处理就显得尤为重要了。
在HTML代码中设置内容样式,一般使用css或者js,那么根据加载优先级以及加载效果,可以自行选择。
js在页面加载完之后加载,所以设置图片样式的时候,会先加载大图,然后突然变小;
css在引入时加载,直接加载缩小的图片(实际占用内存不会缩小);
在web前端,也就是HTML中,如果只设置图片的宽度,那么高度会根据图片原本尺寸进行缩放。
如果后台返回的HTML代码中,不包含<head>标签,则可以直接在HTML字符串前加上一下面的代码(如果包含<head>,则在<head>标签内部添加)。代码含义是,不管用户以前设置的图片尺寸是多大,都缩放到宽度为320px大小。
<head><style>img{width:320px !important;}</style></head>
若需要根据图片原本大小,宽度小于320px的不缩放,大于320px的缩小到320px,那么在HTML字符串前加上一下代码:
在webview的代理中,执行js代码。(下面这段代码是必须有<head>标签的)
如果没有<head>标签,也很简单,只需要给返回的HTML字符串前面拼接一个<head></head>即可。
文章的自动换行也是通过css实现的,书写方式图片缩放类似。在没有<body>标签的情况下,在HTML代码前,直接拼接以下代码即可(若包含<body>,则将代码添加到body标签内部),意思是全部内容自动换行。
在很多App中都会使用到webview,尤其是在加载新闻内容等文章形式的数据时。因为图文混编以及不同字体格式的显示,在iOS进行编辑和显示都是一大问题(当然,iOS中也可以用CoreText进行绘制),但是对于web端来说,一个富文本编辑器就可以完美解决这个问题。所以后台很多时候会直接返回HTML代码拿给前端解析,这时,在客户端对HTML代码的处理就显得尤为重要了。
在HTML代码中设置内容样式,一般使用css或者js,那么根据加载优先级以及加载效果,可以自行选择。
js在页面加载完之后加载,所以设置图片样式的时候,会先加载大图,然后突然变小;
css在引入时加载,直接加载缩小的图片(实际占用内存不会缩小);
一、图片自适应
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;}</styl 4000 e></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();"]; }
二、文章内容自动换行
文章的自动换行也是通过css实现的,书写方式图片缩放类似。在没有<body>标签的情况下,在HTML代码前,直接拼接以下代码即可(若包含<body>,则将代码添加到body标签内部),意思是全部内容自动换行。<body width=320px style=/"word-wrap:break-word; font-family:Arial/">
相关文章推荐
- iOS 获取周几
- 友盟崩溃日志分析
- iOS开发拓展篇—音乐的播放
- iOS开发拓展篇—音效的播放
- IOS 二维码的生成
- iOS 调用Webservice接口
- iOS 多线程小结 ---- (NSThread)
- iOS Debug 速查表
- iOS利用代码添加事件到系统日历中
- iOS 中使用JS提取网页数据,自动提交表单等
- iOS通过经纬度计算两个地点之间的距离
- iOS开发拓展篇—静态库
- 【转】iOS页面间传值的方式(Delegate/NSNotification/Block/NSUserDefault/单例)-- 不错
- IOS AVAudioRecorder 录制音频
- iOS 宏(define)与const的正确用法
- iOS 生成二维码 官方版
- iOS中读取照片库及保存图片或视频到照片库的要点解析
- iOS 9开发小技巧
- 快速掌握iOS之Framework制作流程
- 开源项目之Coding-iOS