iOS中用UIWebView的loadHTMLString后图片和文字失调,图片过大,超过屏幕,文字太小;或者图片太小,文字太大,总之就是不协调。
我们的需求是让图片的大小跟着屏幕的变化而变化,就是动态的去适应屏幕;那么文字的字体就是我们自己可以控制,可大可小。要想达到这样的效果,我们要在用loadHTMLString加载字符串之前对它进行处理。怎么处理呢?什么原理呢?
处理HTMLString的方法:
NSString *htmls = [NSString stringWithFormat:@"<html>
"
"<head>
"
"<style type="text/css">
"
"body {font-size:15px;}
"
"</style>
"
"</head>
"
"<body>"
"<script type='text/javascript'>"
"window.onload = function(){
"
"var $img = document.getElementsByTagName('img');
"
"for(var p in $img){
"
" $img[p].style.width = '100%%';
"
"$img[p].style.height ='auto'
"
"}
"
"}"
"</script>%@"
"</body>"
"</html>",htmlString];
处理HTMLString的原理:
原理就是用一个for循环,拿到所有的图片,对每个图片都处理一次,让图片的宽为100%,就是按照屏幕宽度自适应;让图片的高atuo,自动适应。文字的字体大小,可以去改font-size:15px,这里我用的是15px。根据自己的具体需求去改吧。