检查onsubmit doenst work jquery contactform上的函数
Check functions on onsubmit doenst work jquery contactform
更新。。
代码现在工作
必须更改表单提交中的验证声明。删除了有效的vars等,但它现在工作感谢
固定提交给
$('form').on("submit", function(e) {
//Prevent default
e.preventDefault();
if(validateName() & validateSubject() & validateEmail() & validateMessage())
{
$('form #status').removeClass().addClass('processing').html('Processing...').fadeIn('fast');
// maak variable met alle data die verstuurd kan worden
var formData = $('form').serialize();
//functie om data naar server te sturen
submitForm(formData);
return true;
}
else
{
$('form #status').removeClass().addClass('error')
.html('<strong>Form is not filled in correctly</strong>').fadeIn('fast')
return false;
}
});
您的问题是您没有阻止表单的提交。相反,您会挂接"提交"按钮,然后在出现问题时只显示一条错误消息(但表单仍然会被提交,因此错误消息没有帮助)。
你可以/应该做几件事来解决这个问题。首先,您可能希望将验证代码附加到表单的提交事件(而不是提交按钮的单击事件)。这将确保,如果您将来提供其他提交表单的方法,则不需要单独维护每个方法上的验证挂钩。所以不是:
$('form #submit').click(function(e) {
你可能想要:
$('form').on("submit", function(e) {
其次,如果表单出现问题,则需要在提交处理程序中返回false
。这将导致一个隐含的e.preventDefault()
,它将阻止表单提交:
if (valid != '') {
$('form #status').removeClass().addClass('error')
.html('<strong>Correct these errors<BR></strong>' + valid).fadeIn('fast');
return false; //stop form submission
//Or you could do e.preventDefault(); if you're not ready to end the function yet.
}
这应该能解决你最紧迫的问题。坚持下去!
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- jQuery中是否内置了任何字符串格式化函数
- 检查onsubmit doenst work jquery contactform上的函数