富文本编辑器-Flex不处理htmlText中的换行符



我将RichTextEditorhtmlText属性存储在数据库中。

我在另一个实例中检索它,并希望向用户显示它的第一行纯文本

所以我让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, ""));

最新更新