免责声明: 我不是 JavaScript 专家,我的回答可能不适用于所有浏览器。随时指出任何错误或改进我的答案的方法,使其适用于所有浏览器。
该RichTextArea.getFormatter().insertHTML()
方法调用executeCommand("insertHTML", ...)
JavaScript方法,据我了解,该方法在当前位置创建一个子节点,同时破坏了父节点的格式。因此,任何insertHTML
方法都不会提供所需的行为。
相反,您应该获取包含当前位置的文本对象,并使用它insertData(pos, text)
来插入新文本。这可以通过扩展RichTextArea
类和添加JSNI方法轻松完成。
在以下示例中,我扩展了
RichTextArea
该类并添加了以下 JSNI 方法:
public class CustomRichTextArea extends RichTextArea {
public native void insertText(String text, int pos) /*-{
var elem = this.@com.google.gwt.user.client.ui.UIObject::getElement()();
var refNode = elem.contentWindow.getSelection().getRangeAt(0).endContainer;
refNode.insertData(pos, text);
}-*/;
}
该insertText
方法获取与当前选择关联的文本对象,然后将文本插入到该文本对象中的指定位置。此代码提供了您想要的行为,但我只在 Chrome 中对此进行了测试。
此外,可以通过自动查找当前位置来改进此方法——获取 RichTextArea 的当前位置是完全不同的主题。
我使用以下入口点测试了上面的代码片段:
private CustomRichTextArea crta;
public void onModuleLoad() {
crta = new CustomRichTextArea();
crta.ensureDebugId("cwRichText-area");
crta.setSize("100%", "14em");
RichTextToolbar toolbar = new RichTextToolbar(crta);
toolbar.ensureDebugId("cwRichText-toolbar");
toolbar.setWidth("100%");
Button b = new Button();
b.setText("Insert HTML");
b.addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
crta.setFocus(true);
crta.insertText("ASDF", ((int)crta.getText().length() / 2));
}
});
Grid grid = new Grid(2, 1);
grid.setStyleName("cw-RichText");
grid.setWidget(0, 0, toolbar);
grid.setWidget(1, 0, crta);
// display:
RootPanel.get().add(grid);
RootPanel.get().add(b);
}
我从 GoogleCode 上的项目中获得RichTextToolbar的地方。