- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 GWT RichTextArea 并且需要在当前光标位置插入文本。我阅读了有关使用 RichTextArea.getFormatter().insertHTML() 方法来执行此操作的信息,并且它工作正常。
我的一个问题是,它不是将我的文本作为原始 HTML 插入光标位置,而是关闭当前格式化 HTML 标签,然后围绕我的 HTML 重新打开新的标签。澄清一下,我实际上并没有插入任何类型的 HTML 字符串,只是文本。这是一个例子:
原始 HTML:
<font size="2">Walk the dog</font>
如果我的光标放在“d”之后,并且我调用了 insertHTML("ASDF"),我得到的 html 将是这样的:
<font size="2">Walk the d</font>ASDF<font size="2">og</font>
有什么办法可以避免这种格式转义吗?我需要文本的格式与周围的文本相同。当用户手动输入文本时,它会正确执行此操作。我需要在脚本中做同样的事情。
我不熟悉在 GWT 中编写 native javascript,但我认为可能有一种使用 native 方法实现此目的的简单方法。任何关于如何实现这一目标的想法将不胜感激。我显然可以对 HTML 进行一些后期处理以删除标签,但我想避免这种情况。
最佳答案
免责声明:我不是 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 的当前位置是 completely different topic。 .
我用以下入口点测试了上面的代码片段:
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);
}
我在哪里获得 RichTextToolbar来自 GoogleCode 上的项目。
关于javascript - GWT RichTextArea 的 insertHtml,无需退出格式化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16818520/
我正在从事的项目需要使用 toString 方法打印银行帐户余额。我不允许向当前程序添加任何方法,但我需要将 myBalance 变量格式化为 double 型,该变量保留两位小数而不是一位。在这个特
我喜欢 Visual Studio (2008) 格式化 C# 代码的方式;不幸的是,在编写 C++ 代码时,它的行为方式似乎有所不同。 比如我这样写代码的时候: class Test { publi
Scanner scan = new Scanner(System.in); System.out.println("Enter three positive integers seperated b
在 aspose(使用 C#)中用于格式化数字的正确样式属性是什么。我想做两件事: 1) 将五位数字格式化为邮政编码。(我不太确定使用哪个 Style 属性来获取自定义 excel 邮政编码格式) 2
我希望用户输入从 00 到 23 和从 00 到 59 的 Local.Time 的小时和分钟,我将其扫描为一个 int。它有效,但对于从 00 到 09 的值,int 忽略 0,然后将其放置为 0,
大家好, 请查看上面的图片,我有两张 table 。在下面代码的第一个表中,我得到了这种格式。 但我想像 Table2 那样格式化,每个合并单元格中的行数是动态的,而且不一样。 有没有办法像table
我在一个 laravel 网站工作,我只是想知道是否有办法为用户格式化 created_at 值,因为现在它类似于以下内容: 2017-09-20 13:41 但我更愿意将其格式化为易于阅读的格式,例
我正在尝试在 JTextPane 中进行一些基本的格式化。为此,我决定使用 html(HTMLDocument 和 HTMLEditorKit)。 这里是按钮的操作监听器代码,应使所选文本变为粗体 b
是否有规则或插件会导致 es-lint 错误或警告,如果范围内的声明没有像下面那样间隔,赋值运算符的对齐方式相同? var a = 'a'; var bb = 'b'; var ccc = 'd
我正在尝试重新格式化 LinkedHashMap 的输出以排除逗号和大括号。 这是我的看跌期权: token.put("[Server.Protocol]", url.getProtocol() +
我有一个程序,可以从文本文件中读取大量文本,然后根据文本内容随机化内容以显示为短篇故事。该程序可以运行,但最后一部分(我显示的 Material )非常笨重且效率不高,我想知道是否有人对如何更有效地获
我正在尝试将 VIM 作为我的 ruby/rails 编辑器。太胖了,我对它的功能印象深刻 并且我能够安装以下插件以提供更好的 IDE 体验 自动配对 Better-snipmate-snippe
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我有两个 jQuery 函数。我想先运行下面的第一个,然后在该函数完成后运行另一个。通常我会在代码的第一部分添加一个函数,但不确定如何使用这个 block 来做到这一点,或者它是否是正确的方法。 简而
在 Python 2.7 中,我有一个包含数字 1-25 字符串的列表(例如)。打印它们时,我希望列表打印 5 行,每行 5 个数字。 理想情况下: >>> print(myList) ['1', '
我有以下功能来打印借阅者已取出的书籍列表。 void searchBorrowerLoans(int a) { int i; for (i = 1
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 Improv
我正在尝试实现一个用作 ListView header 的 TextView。我想对其进行格式化,以便我基本上有一个以第一行为中心的标题,然后是以下几行的附加信息。如何格式化文本/字符串以创建这种格式
我尝试格式化数字字段 select to_char(12315.83453, 'FM999999999999D9999') 在这种情况下一切正常。结果是 12315.8345 但是如果值在0到1之间
我有一个带有 BigDecimal 字段的类。我把这个对象放到 JSP(Spring MVC)中。而且我需要显示十进制不带零的 BigDecimal 字段(20.00 就像 20),这就是为什么我的
我是一名优秀的程序员,十分优秀!