我将RichTextEditor
的htmlText
属性存储在数据库中。
我在另一个实例中检索它,并希望向用户显示它的第一行为纯文本
所以我让Flex通过使用类似的函数来处理转换
var editor:TextField = new TextField();
editor.htmlText = htmlTextFromDb;
var converted:String = editor.text;
然而,问题是这种转换不能正确地处理行。我把所有东西都放在一行!
假设我从数据库中得到的是这个
<TEXTFORMAT LEADING="2"><P ALIGN="LEFT"><FONT FACE="Arial" SIZE="12" COLOR="#000000" LETTERSPACING="0" KERNING="0">This is line one</FONT></P></TEXTFORMAT><TEXTFORMAT LEADING="2"><P ALIGN="LEFT"><FONT FACE="Arial" SIZE="12" COLOR="#000000" LETTERSPACING="0" KERNING="0">This is line two</FONT></P></TEXTFORMAT>
只要我说editor.htmlText = htmlTextFromDb
,editor.html文本就变成
<TEXTFORMAT LEADING="2"><P ALIGN="LEFT"><FONT FACE="Arial" SIZE="12" COLOR="#000000" LETTERSPACING="0" KERNING="0">This is line oneThis is line two</FONT></P></TEXTFORMAT>
它的作用就好像没有新的线路一样。
我该如何解决此问题?
我会考虑这个HTML文本的服务器端转换。
但在AS中,只有您可以通过在换行处进行拆分,然后将行转换为文本,然后将所有内容串联起来,逐行完成。有点难看,但应该行得通。
var editor:TextField = new TextField();
var result:Array = new Array();
var input:Array = htmlTextFromDb.split(/n/);
for each( var line:String in input) {
editor.htmlText = line;
result.push(editor.text);
}
var converted:String = result.join("n");
编辑
用正则表达式替换标记是另一种方法。首先用换行符替换最后一段</P>
,然后删除所有剩余的标记。
var lnRegExp:RegExp = new RegExp("</P>", "g");
s = s.replace(lnRegExp, "n");
var tagRegExp:RegExp = new RegExp("<([^>\s]+)(\s[^>]+)*>", "g");
trace(s.replace(tagRegExp, ""));