我正在寻求执行基本表单发布,但以下内容在 Chrome 和 Safari 中两次提交到服务器(但在 Firefox 中的行为与预期相同):
<form id="create-deck-form" action="/decks/create" method="post">
<fieldset>
<legend>Create new deck</legend>
<label for="deck-name-field">Name</label>
<input id="deck-name-field" name="deck-name-field" type="text" value="" maxlength="140" />
<label for="tag-field">Tags</label>
<input id="tag-field" name="tag-field" type="text" value="" maxlength="140" />
<input class="add-button" type="submit" value="Create" />
</fieldset>
</form>
我想onsubmit
在提交之前使用该属性对字段进行验证,但是无论返回值为true
,表单都会提交两次。
我试图将 jQuery 处理程序绑定到表单,但在这里,默认行为不会被阻止,表单被提交两次,例如:
<script type="text/javascript">
$(document).ready(function() {
$("#create-deck-form").submit(function(event){
if($("#deck-name-field").val() == "") {
event.preventDefault();
alert("deck name required");
}
});
});
</script>
虽然我认为对于一双新的眼睛来说这里有一些明显的错误,但我很困惑为什么提交,无论是否经过验证,都会在 Chrome 和 Safari 中向服务器发送重复的帖子。我会很感激任何见解。