【发布时间】:2016-05-11 11:29:42
【问题描述】:
我创建了以下带有标准 html 验证的表单。对于这个表单,我想在按下提交按钮时避免刷新页面。因此,在我的 jquery 代码中,我添加了preventDefault()。哪些工作不刷新页面,但它也删除了 html5 验证?我怎样才能同时应用这两个东西?
表格
<form method="post" action="">
<div class="reg_section personal_info">
<input type="text" name="username" id="title" value="" placeholder="title" required="required" maxlength="25">
<textarea name="textarea" id="description" value="" placeholder="Beskrivelse" required="required" minlength="100"></textarea>
</div>
<div>
<span class="submit" style="text-align: left; padding: 0 10px;"><input type="submit" id="insert" value="Tilføj"></span>
<span class="submit" style="text-align: right; padding: 0 10px;"><input TYPE="button" value="Fortryd" onclick="div_hide();"></span>
</div>
</form>
jquery
$("#insert").click(function(e) {
e.preventDefault(); // prevent default form submit
if(!$('#description').val() == "" && !$('#title').val() == "" && $('#description').val().length >= 100) {
div_hide();
$.post("insert.php",
{
title: $('#title').val(),
body: $('#description').val(),
longitude: currentMarker.lng(),
latitude: currentMarker.lat()
},
function (data) { //success callback function
}).error(function () {
});
}
});
【问题讨论】:
-
它正在取消 HTML5 验证,因为您没有提交表单。当您尝试提交不符合字段等参数的表单时,验证就会启动。我想如果您以这种方式处理它,您将需要包含一些 JS/jQuery 验证器
标签: javascript jquery html validation