使用UIWebView中html标签显示富文本
使用UIWebView中html标签显示富文本
用UIWebView来渲染文本并期望达到富文本的效果开销很大哦!
Work
本人此处直接加载自定义字体"新蒂小丸子体",源码不公开,望见谅.
代码如下:
渲染后效果如下图所示,效果是不是挺不错的呢.
我们再把尽头两个字渲染成红色试试.
源码:
- (void)viewDidLoad [super viewDidLoad]; // 注册字体 REGISTER_FONT(bundleFont(@"XinDiXiaoWanZi.ttf"), @"新蒂小丸子体"); NSString *jsString = [NSString stringWithFormat: @" html \n" // 设置字体的css样式 " head \n" " style type=\"text/css\" \n" "body {font-size: %f; font-family: \"%@\"; color: %@;}\n" " /style \n" " /head \n" // 字符串显示部分 " body %@ /body \n" " /html ", 37.f, // 字体大小 CUSTOM_FONT(@"新蒂小丸子体", 0), // 字体类型 @"#000000", // 字体颜色 @"走向世界的 span "color:red;\" 尽头 /span
UIWebView *webView = [[UIWebView alloc] initWithFrame:CGRectMake(0, 100, 320, 70)]; [webView loadHTMLString:jsString baseURL:nil]; [self.view addSubview:webView]; viewDidLoad
效果如下:
Question
Currently I am working on iOS client for web-chat. Thus chat messages have HTML tags (bold, italic, underlined, font color, images (smiles), etc.). For example:
最近,我要给一个网页聊天的网站做一个客户端.这些聊天信息包含了很多HTML标签(bold, italic, underlined, font color, images (smiles), etc.),例如:
b bold /b i italic /i !--smile:bird-- img alt="bird" src="http://www.site.com/engine/data/emo_chat/bird.gif" / !--/smile-- ordinaty text
For the moment I have 2 ideas how to display messages:
当下,我有两个思路来显示这些信息:
Add UIWebView to tables cell. But I think that its not an option, because we will have a lot of messages and a lot of WebViews. 将UIWebView添加到cell中,但这个备选方案问题多多,因为我有很火很多消息需要显示,同时也需要很多很多的WebView. Add UITextView to tables cell, parse HTML tags and make necessary changes to attributed string. But UITextView doesnt support images (if I am right). 将UITextView添加到cell中,解析HTML标签并转换成富文本标签.但是,UITextView不支持图片显示(如果我没猜错的话).Is there any other (better) way to display such data (styled text + images)?
是否有其他更好的方式来显示富文本加图片呢?
Answer
Using a webview per-cell is not going to work as you suspect. Webviews take a noticeable time to render which means you will likely end up with old webview content being momentarily displayed in reused cells until the new content renders. Webview is also a pretty heavy-weight UI element and you will encounter performance issues with having many of them on the screen updating at once.
将webView添加到cell中绝对达不到你的预期.WebView需要很长很长时间来渲染,在cell中重用你就会死.WebView是开销非常大的UI控件.
You will want to parse the HTML text you are given into an attributed string using a library like DTCoreText. From here, if you can target iOS 6 or later you can set the attributedText property on a standard UILabel. If you need to target earlier iOS versions you can again use DTCoreText, specifically the DTAttributedLabel or DTAttributedTextCell components.
也许你需要 DTCoreText 来帮助你将HTML标签解析成富文本.
The parsing and NSAttributedString rendering can all be done manually using an XML parser and CoreText, but DTCoreText will make your life much easier.
虽然解析HTML以及富文本的渲染都可以通过手动的XML解析器以及CoreText来实现, 只不过 DTCoreText 让你更轻松而已.
Update: You mentioned in a comment that you want support for img/ . DTCoreText does have some basic image support, but this is a really hard problem if you are rendering text with CoreText because you have to make text flow around the image correctly, and reserve some space in the core text renderer to put your image into. If there is just a single image for each cell, I would suggest you manually extract the image path/url and lay it out with a UIImageView alongside your text.
注意:你提到了一个要素就是想支持 img/ .DTCoreText 支持几种基本的image,但是如果你想用 CoreText 来实现这种图文混排的工作会让你非常蛋疼.如果你仅仅是展示一张图片到一个cell当中.我建议你直接用UIImageView来显示图片算了.
相关文章
- 怎么html文字下划线,HTML怎么设置下划线?html文字加下划线方法
- html 转换为cshtml,使用Html而不是csHtml
- HTML添加背景图片_html背景图片铺满网页
- 网页实时显示时间_html页面布局代码
- HTML基础第二课(冲浪笔记2)
- html小案例
- 解决java中html转word文档,转成功后的word文档在断网情况下无法显示图片问题「建议收藏」
- WordPress天气显示-自定义HTML代码设置
- python+requests+excel+unittest+ddt接口自动化数据驱动并生成html报告(优化版)
- java将html转换为纯文本的代码详解编程语言
- html div 不换行超出显示省略号详解编程语言
- 把文章里边的html标签去掉(去掉文字的样式,显示css设置的样式)详解编程语言
- 文件Linux 打开 HTML 文件的方法(linux打开html)
- html中行级元素的居中显示。详解编程语言
- MySQL与HTML的无缝连接(html与mysql连接)
- 文档为何使用Linux创建HTML文档?(linux创建html)
- HTML 属性
- HTML 画布
- Linux环境实现HTML文件编辑(linux编辑html)
- Framework7 6.3.0 发布,全功能 HTML 框架
- 去除内容中的html
- HTML标记第1/2页
- XML中显示HTML的小技巧
- ScriptHtml函数之过滤html标记的asp代码
- javascriptXML数据显示为HTML一例
- javascript控制html元素显示/隐藏实现代码
- html页面显示年月日时分秒和星期几的两种方式
- python将xmlxsl文件生成html文件存储示例讲解
- html+ashx表单提交示例
- js通过html()及text()方法获取并设置p标签的显示值
- 使用C#获取网页HTML源码的例子