根据应用需求,需要将后台传过来的html标签文本显示在页面上,首先想到的是用WKWebview显示可以实现,尝试用lable加载html,代码以及效果如下所示,发现表格的边框样式加载不出来
NSString *str = @"罗梦槐,您好!您的借款项目【0903.按月3.02】债权转让已经完成,当前持有信息如下:
用户名 | 债权持有金额 |
13944831072 | 2200.00 |
13944831077 | 600.00 |
13944831078 | 200.00 |
13944831078 | 200.00 |
13944831078 | 1800.00 |
13944831078 | 800.00 |
13944831079 | 400.00 |
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的加载但是相对更耗内存这里不建议使用,希望对遇到同样问题的朋友有帮助