根据应用需求,需要将后台传过来的html标签文本显示在页面上,首先想到的是用WKWebview显示,虽然可以实现但是感觉比较耗内存。尝试用lable加载html,代码以及效果如下所示,发现表格的边框样式加载不出来
NSString *str = @"罗梦槐,您好!您的借款项目【0903.按月3.02】债权转让已经完成,当前持有信息如下:<table border=‘1‘ cellpadding=‘0‘ width=‘80%;‘ cellspacing=‘0‘><tr><td align=‘center‘>用户名</td><td align=‘center‘>债权持有金额</td></tr><tr><td align=‘center‘>13944831072</td><td align=‘center‘>2200.00</td></tr><tr><td align=‘center‘>13944831077</td><td align=‘center‘>600.00</td></tr><tr><td align=‘center‘>13944831078</td><td align=‘center‘>200.00</td></tr><tr><td align=‘center‘>13944831078</td><td align=‘center‘>200.00</td></tr><tr><td align=‘center‘>13944831078</td><td align=‘center‘>1800.00</td></tr><tr><td align=‘center‘>13944831078</td><td align=‘center‘>800.00</td></tr><tr><td align=‘center‘>13944831079</td><td align=‘center‘>400.00</td></tr></table>"; UILabel *lab = [[UILabel alloc] initWithFrame:CGRectMake(15, 100, K_SCREEN_WIDHTH-30, 300)]; lab.numberOfLines = 0; [self.view addSubview:lab]; NSAttributedString * attrStr = [[NSAttributedString alloc] initWithData:[str dataUsingEncoding:NSUnicodeStringEncoding] options:@{ NSDocumentTypeDocumentAttribute: NSHTMLTextDocumentType } documentAttributes:nil error:nil]; lab.attributedText = attrStr; lab.font = [UIFont systemFontOfSize:15];
然后抱着试试的心态用textview加载html标签发现边框样式可以显示出来了,应该是底层内部对lab和textview做了不同的处理,代码以及效果如下
UITextView *textView = [[UITextView alloc]initWithFrame:CGRectMake(15, 400, K_SCREEN_WIDHTH-30, 300)]; textView.userInteractionEnabled = NO; [self.view addSubview:textView]; NSAttributedString * attrStr = [[NSAttributedString alloc] initWithData:[str dataUsingEncoding:NSUnicodeStringEncoding] options:@{ NSDocumentTypeDocumentAttribute: NSHTMLTextDocumentType } documentAttributes:nil error:nil]; textView.attributedText = attrStr; textView.font = [UIFont systemFontOfSize:15];
总结textView和lable都可以加载html标签内容,但是textview相比于lable可以同时加载出标签里的样式,当然通过webview也可以实现对html的加载但是相对更耗内存这里不建议使用,希望对遇到同样问题的朋友有帮助
原文地址:https://www.cnblogs.com/zk1947/p/9599424.html
时间: 2024-10-10 01:19:12