ios webview image 适应宽高


后台返回 一段html字符串 里面有图片但是图片很大 webview 的content会出现上下和左右滑动的滚动条,为了让图片适应webview 宽度做了一些修改。

1.首先得有一个webview
UIWebView * detailWebView = [[UIWebView alloc] initWithFrame:yourFrame];
    detailWebView.delegate = self;
    NSString * webContentStr = [self.infoDict stringForKey:@"Description"];
    NSLog(@"webContentStr==%@",webContentStr);
    [detailWebView loadHTMLString:webContentStr baseURL:nil];

- (void)webViewDidFinishLoad:(UIWebView *)webView
{
	
//图片适应宽高
    [webView stringByEvaluatingJavaScriptFromString:
     @"var script = document.createElement('script');"
     "script.type = 'text/javascript';"
     "script.text = \"function ResizeImages() { "
     "var myimg,oldwidth;"
     "var maxwidth=document.body.clientWidth;" //缩放系数</span>
     "for(i=0;i <document.images.length;i++){"
     "myimg = document.images[i];"
     "if(myimg.width > maxwidth){"
     "oldwidth = myimg.width;"
     "myimg.width = maxwidth;"
     "myimg.height = myimg.height * (maxwidth/oldwidth);"
     "}"
     "}"
     "}\";"
     "document.getElementsByTagName('head')[0].appendChild(script);"];
    
    [webView stringByEvaluatingJavaScriptFromString:@"ResizeImages();"];



//webview 的高度适应内容高度(若不想适应可以去掉下面这些)

    NSString *curHeight = [webView stringByEvaluatingJavaScriptFromString:@"document.body.scrollHeight;"];//缩放后的内容高度
    
//    UIScrollView *scrollView = (UIScrollView *)[[webView subviews] objectAtIndex:0];//这两行是么可有缩放的情况下内容高度
//    CGFloat webViewHeight = [scrollView contentSize].height;
    
    CGRect newFrame = webView.frame;
    newFrame.size.height = [curHeight floatValue];
    webView.frame = newFrame;

}

借鉴http://zxs19861202.iteye.com/blog/1853102

http://bbs.9ria.com/thread-230299-1-1.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值