的事件?-6ren"> 的事件?-我有一个输入字段: 并尝试在 js 中捕获更改事件,如下所示: let dateInput = document.querySelector('input[type=date]'); dateInp-6ren">
gpt4 book ai didi

java - 如何通过 wicket ajax 行为捕获来自 <input type ="date"> 的事件?

转载 作者:行者123 更新时间:2023-12-02 09:10:21 24 4
gpt4 key购买 nike

我有一个输入字段:

<input type="date" wicket:id="date">

并尝试在 js 中捕获更改事件,如下所示:

let dateInput = document.querySelector('input[type=date]');
dateInput.onchange = log;


function log() {
console.log(this + " - " +event+": " + this.value);
}

但是在java中有些行为如下:

DateTextField dateField = new DateTextField("dateField");
dateField.add(new AjaxEventBehavior("onchange") {
@Override
protected void onEvent(AjaxRequestTarget target) {
System.out.println("hello");
}
}

或者

DateTextField dateField = new DateTextField("dateField");
dateField.add(new OnChangeAjaxBehavior() {
@Override
protected void onUpdate(AjaxRequestTarget target) {
System.out.println("hello");
}
});

或者

DateTextField dateField = new DateTextField("dateField");
dateField.add(new AjaxFormComponentUpdatingBehavior("onchange") {
@Override
protected void onUpdate(AjaxRequestTarget target) {
System.out.println("hello");
}
});

无法捕捉此事件。

DateTextField 是 org.apache.wicket.extensions.markup.html.form.DateTextField;

最佳答案

我找到了解决方案 - 需要正确的日期模式,输入的模式必须与 java Date 的模式匹配。这是工作:

DateTextField dateField= new DateTextField("dateField", Model.of(new Date()),"yyyy-MM-dd");
dateField.add(new OnChangeAjaxBehavior() {
@Override
protected void onUpdate(AjaxRequestTarget target) {
System.out.println("hello");
}
});

关于java - 如何通过 wicket ajax 行为捕获来自 &lt;input type ="date"> 的事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59476498/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com