> 웹 프론트엔드 > HTML 튜토리얼 > WebView加载HTML图片大小自适应与文章自动换行_html/css_WEB-ITnose

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

PHP中文网
풀어 주다: 2016-06-24 11:35:53
원래의
1636명이 탐색했습니다.

在很多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>
로그인 후 복사


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

<head><style>img{max-width:320px !important;}</style></head>
로그인 후 복사


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();"];}
로그인 후 복사

二、文章内容自动换行

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

<body width=320px style=/"word-wrap:break-word; font-family:Arial/">
로그인 후 복사

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

 





관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿