iOS - label适配HTML(富文本)的代码


网络解析后 有一个HTML字符串 需要在label显示(一般是要求显示的内容有颜色 字体 背景颜色的变化) 如果不做处理 显示的就是HTML代码内容 处理方法如下
 
已知网络请求得到一个HTML 字符串 self.HTMLstring


1.富文本显示 不考虑高度自适应

 NSMutableAttributedString *str=  [[NSMutableAttributedString alloc] initWithData:[self.HTMLstring dataUsingEncoding:NSUnicodeStringEncoding] options:@{NSDocumentTypeDocumentAttribute:NSHTMLTextDocumentType} documentAttributes:nil error:nil];
 [str addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:17.0] range:NSMakeRange(0, str.length)];
 synthesizeCell.nameLabel.attributedText =  str;


2.富文本label的高度自适应

   NSMutableAttributedString *str=  [[NSMutableAttributedString alloc]
                                      initWithData:[string dataUsingEncoding:NSUnicodeStringEncoding]
                                      options:@{NSDocumentTypeDocumentAttribute:NSHTMLTextDocumentType}
                                      documentAttributes:nil
                                      error:nil];
    
    [str addAttribute:NSFontAttributeName
                value:[UIFont systemFontOfSize:kScaleW(16) weight:UIFontWeightSemibold]
                range:NSMakeRange(0, str.length)];
    
    CGRect rect = [self.contentLab.attributedText boundingRectWithSize:CGSizeMake(self.contentLab.width, 0)
                                                               options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading
                                                               context:nil];
    self.contentLab.attributedText = str;
    [self.contentLab mas_updateConstraints:^(MASConstraintMaker *make) {
        make.height.mas_equalTo(rect.size.height);
    }];


原文链接:https://blog.csdn.net/flg1554112450/article/details/53032616

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值