Heim > Web-Frontend > HTML-Tutorial > WebView加载HTML图片大小自适应与文章自动换行_html/css_WEB-ITnose

WebView加载HTML图片大小自适应与文章自动换行_html/css_WEB-ITnose

PHP中文网
Freigeben: 2016-06-24 11:35:53
Original
1661 Leute haben es durchsucht

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

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

  • js在页面加载完之后加载,所以设置图片样式的时候,会先加载大图,然后突然变小;

  • css在引入时加载,直接加载缩小的图片(实际占用内存不会缩小);

一、图片自适应

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

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

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

<head><style>img{width:320px !important;}</style></head>
Nach dem Login kopieren


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

<head><style>img{max-width:320px !important;}</style></head>
Nach dem Login kopieren


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

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

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

- (void)webViewDidFinishLoad:(UIWebView *)webView {    

[webView stringByEvaluatingJavaScriptFromString:     
@"var script = document.createElement(&#39;script&#39;);"     
"script.type = &#39;text/javascript&#39;;"     
"script.text = \"function ResizeImages() { "         
"var myimg,oldwidth,oldheight;"         
"var maxwidth=320;"// 图片宽度         
"for(i=0;i  maxwidth){"                 
"myimg.width = maxwidth;"             
"}"         
"}"     
"}\";"     
"document.getElementsByTagName(&#39;head&#39;)[0].appendChild(script);"];    
[webView stringByEvaluatingJavaScriptFromString:@"ResizeImages();"];}
Nach dem Login kopieren

二、文章内容自动换行

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

<body width=320px style=/"word-wrap:break-word; font-family:Arial/">
Nach dem Login kopieren

以上就是WebView加载HTML图片大小自适应与文章自动换行_html/css_WEB-ITnose的内容,更多相关内容请关注PHP中文网(www.php.cn)!

 





Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage