计算html文本高度

ios 原生控件加载本地HTMLString有三种方式:UILabel,UITextview,UIWebview;其中UILable,UITextview都是借助于attributedText属性加载富文本。

  一:UILable 加载本地HTMLString

      第一步:先把HTMLString 转化为NSAttributedString:



- (NSAttributedString *)attributedStringWithHTMLString:(NSString *)htmlString

{

NSDictionary *options = @{ NSDocumentTypeDocumentAttribute : NSHTMLTextDocumentType,

NSCharacterEncodingDocumentAttribute :@(NSUTF8StringEncoding) };

NSData *data = [htmlString dataUsingEncoding:NSUTF8StringEncoding];

return [[NSAttributedString alloc] initWithData:data options:options documentAttributes:nil error:nil];

}


   第二步:计算UIlable记载富文本之后的高度重置lable的frame;

  CGFloat height =  [self.lable.attributedText boundingRectWithSize:CGSizeMake(Device_Width, CGFLOAT_MAX) options:NSStringDrawingUsesLineFragmentOrigin context:nil].size.height;//针对富文本有专门的计算动态高度的方法,与nsstring 大同小异;

self.lable.height = height;

二:UItextview 与UIlable 加载方式一样也是通过上述方法计算高度


三:UIWebView加载本地HTMLString

    以cell中嵌套UIWebView举例,只举例一个cell,如果多个cell,cell的高度还是要放在对应的model中存储,否则会造成复用;

   当cell中嵌套UIWebview 时,需要在返回高度的地方返回cell.height ,可是webview的高度只有在加载HTMLString之后调动结束加载HTMLString之后才能获得UIWebview的高度,从而cell 的高度才能获得。

            首先,可以定义一个返回cell 高度的类变量,用静态变量存储,用来在webview加载完成之后重新存储新的高度。




   



 那么问题来了,   只能在赋值之后webView加载HTMLString,执行代理方法,执行完之后需要重新返回cell 的高度,需要通知UITableview进行刷新,然后就会出现死循环,所以增加判断 staticHeight == height +1判断,‘1’是contenview与cell 的分割线的高度。

  最后总结下,如果是纯HTMLString文本,可以使用UILable或者UItextview,(但是字体会小很多,相对于UIWebview加载来说,大神有知道的指点下),如果是带有图片的HTMLString,可以使用UIWebview进行加载;  

 demo地址:示例demo加载HTMLString 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值