0

我在 GWT 中创建表,其中一列包含具有输入的单元格。我想在输入中的文本更改时获取信息。在我的单元格中,我重载render()onBrowserEvent()方法。这是代码:

public HourPickerCell() {
    super("change", "keyup");
}

@Override
public void render(Context context, String value, SafeHtmlBuilder sb) {
    if (value == null) {
        return;
    }
    sb.appendHtmlConstant("<input class=\"hourPicker\" type=\"text\" value=\"" + value + "\"></input>");        
}


@Override
public void onBrowserEvent(Context context, Element parent, String value, NativeEvent event, ValueUpdater<String> valueUpdater) {
    System.out.println(event.getType());
    super.onBrowserEvent(context, parent, value, event, valueUpdater);

    if (event.getType().equals("change")) {
        EventTarget eventTarget = event.getEventTarget();
        if (!Element.is(eventTarget)) {
            return;
        }
        if (parent.getFirstChildElement().isOrHasChild(Element.as(eventTarget))) {
            InputElement input = (InputElement) parent.getFirstChild();
            valueUpdater.update(input.getValue());
        }
    }       
}

如您所见,我尝试捕捉change事件。在 Firefox 和 chrome 上一切正常。当我在输入中写一些东西,然后按到其他单元格时,我会在控制台中得到以下结果:

keyup keyup keyup keyup keyup keyup keyup change keyup

其中一个事件是“改变”——这就是我需要的。不幸的是,在 Internet Explorer 上我只收到:

keyup keyup keyup keyup keyup keyup keyup

没有更改事件。谁能告诉我问题出在哪里?有什么办法可以解决吗?

4

1 回答 1

0

在 Internet Explorer 中,change事件不会冒泡 [1],因此您必须在input元素上监听事件。其他浏览器都实现了change事件冒泡的 HTML5 行为 [2]。

我不知道正确的修复方法,但您可能最好使用或复制TextInputCell已经完成所有艰苦工作的方法。

[1] http://msdn.microsoft.com/en-us/library/ie/ms536912(v=vs.85).aspx
[2] http://dev.w3.org/html5/spec/common- input-element-apis.html#event-input-change


附带说明一下,您的render方法不安全(如果value包含引号怎么办?)您可能想要使用SafeHtmlUtils或 a SafeHtmlTemplates(参见代码TextInputCell

于 2012-11-19T11:59:46.820 回答