很简单,我单击具有type="submit"
的输入,并且不提交表单。
我已经搜索了此问题的解决方案,但他们说我应该检查我是否有嵌套表单,而我没有,只是使用了一个。他们还说这可能是放错了位置的标记,但是我已经遍历整个HTML,并且标记很好。
我在HTML中有以下代码块:
<div id="form-options-div" style="margin-top:10px;">
<input class="btn btn-primary" type="submit" wicket:id="saveClientButton" id="save-client-button" />
<input class="btn" type="button" id="close-client-button" wicket:id="closeClientButton"/>
</div>
我在Java代码中使用
AjaxButton
表示saveClientButton
。我要覆盖
onSubmit(AjaxRequestTarget, Form<?>)
。我会发布整个Java代码,但是在方法的开头有一个记录器,以查看是否被调用:logger.debug("ON SUBMIT");
因此它不在方法内部。有趣的是,当我重写Form
onSubmit()
方法而不是AjaxButton方法时,页面实际上会重新加载。但仅此而已,仍未调用onSubmit方法。为什么会这样呢?
编辑:
private Button saveClientBtn;
saveClientBtn = new AjaxButton(WICKET_ID_SAVE_CLIENT_BUTTON) {
@Override
public void onError() {
logger.debug("Error on submit...");
}
@Override
protected void onSubmit(AjaxRequestTarget target, Form<?> form) {
//code....
}
};
closeClientButton
是否会干扰正常行为?我不知道,因为按钮类型是button
,而不是submit
。editClientForm = new Form<Client>(WICKET_ID_EDIT_CLIENT_FORM);
add(editClientForm);
editClientForm.add(saveClientBtn);
编辑2:
OK,我决定不使用AjaxButton,而是改写
onSubmit()
和onError()
形式。单击该按钮时,我看到调用了onError()
。现在,我需要找到原因。好的,我放了一个FeedbackPanel。它给了我以下信息:
'[Page class = EditClientPage, id = 6, render count = 1]' is not a valid EditClientPage.
此外,该错误还会出现4次,如下所示:
'[Page class = EditClientPage, id = 6, render count = 1]' is not a valid EditClientPage.
'[Page class = EditClientPage, id = 6, render count = 1]' is not a valid EditClientPage.
'[Page class = EditClientPage, id = 6, render count = 1]' is not a valid EditClientPage.
'[Page class = EditClientPage, id = 6, render count = 1]' is not a valid EditClientPage.
此错误是什么意思?
最佳答案
确保您有一个表单标签。
例如。:
<html>
<body>
<form wicket:id="form">
<div wicket:id="registration">
Display the RegistrationInputPanel
</div>
<input type=”submit” wicket:id="register" value="Register"/>
</form>
</body>
</html>
和java类:
public class RegistrationPage extends Page {
public RegistrationPage(IModel<Registration> regModel) {
Form<?> form = new Form("form");
form.add(new RegistrationInputPanel("registration", regModel);
form.add(new SubmitButton("register") {
public void onSubmit() {
}
});
add(form);
}
}