2

当我运行以下代码时:

import java.io.IOException;
import java.io.Reader;
import java.io.StringReader;

import javax.swing.text.BadLocationException;
import javax.swing.text.EditorKit;
import javax.swing.text.Element;
import javax.swing.text.html.HTMLDocument;
import javax.swing.text.html.HTMLEditorKit;
    .
    .
    .
        String content = "x";
        String html = "<html><body><dyn/>" + content + "<dyn/></body></html>";
        final Reader reader = new StringReader(html);
        final EditorKit editorKit = new HTMLEditorKit();

        HTMLDocument hTMLDocument = new HTMLDocument();
        editorKit.read(reader, hTMLDocument, 0);
        Element defaultRootElement = hTMLDocument.getDefaultRootElement();
        Element branchElement = defaultRootElement.getElement(1).getElement(0);
        for (int i = 0; i < branchElement.getElementCount(); i++) {
            Element element = branchElement.getElement(i);
            System.out.print(element);
        }

我得到以下输出:

LeafElement(dyn) 1,2
LeafElement(content) 2,3
LeafElement(dyn) 3,4
LeafElement(content) 4,5

但是,如果我将值更改content" "

    String content = " ";

我得到这个输出:

LeafElement(dyn) 1,2
LeafElement(dyn) 2,3
LeafElement(content) 3,4

为什么内容是为LeafElement构造的"x",而不是为构造的" "?我想LeafElement" ". 我做错了什么还是 or 有HTMLDocument问题HTMLEditorKit

4

2 回答 2

1

对编辑器工具包不太了解,但也许您可以使用&nbsp;而不是“”。

于 2009-08-21T19:04:16.293 回答
1
  • 我希望能解释为什么会发生这种情况。

这只是 HTML 中空格折叠的产物。由于您插入的那个空间是两个<dyn/>标签之间的唯一内容,因此解析器会忽略它,因此不会由 LeafElement 表示。

  • 可能的解决方案

正如 camickr 提到的,您必须使用不间断的空间实体来保留所有空格。但是,由于您无法控制 HTML,最好的办法是自定义 HTMLEditorKit 的解析器。也许以下资源可能会派上用场:

希望这可以帮助!

于 2013-11-09T16:08:22.960 回答