检查所有函数是否为真,然后执行模态窗口
check if all functions are true and then execute modal window
我正在尝试做一些表单验证,其中包括检查下拉菜单是否为空,检查所有输入区域是否为空,并验证电子邮件字段。我有一些函数会根据输入返回真/假。我现在要做的是在一个函数中检查所有的验证函数,如果是真的,我想打开一个模态窗口。我所有的验证函数都返回真(如预期的那样,这工作得很好),但我的嵌套函数返回假?
function checkAll() {
if (ValidateEmail() && checkIfEmpty() && checkDrop()) {
console.log(true);
} else {
console.log(false);
}
}
function checkDrop() {
if ($("#hospitals").val() == null) {
console.log(false);
return false;
} else {
console.log(true);
return true;
}
}
function ValidateEmail() {
if (/^'w+(['.-]?'w+)*@'w+(['.-]?'w+)*('.'w{2,3})+$/.test(form1.email.value)) {
console.log(true);
return true;
} else {
console.log(false);
return false;
}
}
function checkIfEmpty() {
$('#form1 input').each(function () {
if (!$.trim(this.value).length) {
console.log(false);
return false;
} else {
console.log(true);
return true;
}
});
}
您的checkIfEmpty
函数没有返回
里面有一个$('#form1 input').each(function(){});
循环,这个循环的返回值没有传递给外部函数。基本上,jQuery .each
函数中的return true
只停止当前迭代,返回false停止整个循环。在这种情况下,你必须在循环之外保存一个返回值。例如:
function checkIfEmpty() {
var returnValue = true;
$('#form1 input').each(function () {
if (!$.trim(this.value).length) {
console.log(false);
returnValue = false;
return false; // this stops the itteration
} else {
console.log(true);
return true; // this has absolutely no effect in your case
}
});
return returnValue;
}
相关文章:
- jQuery-等待此元素,然后执行1次
- 方法来查看jQuery文件是否已完全加载,然后执行与其相关的函数
- 识别javascript,然后执行“;包括“;
- 首先验证表单,然后执行 Ajax 调用
- Phantomjs 检查响应标头,然后执行某些操作
- 等待多个条件,然后执行函数
- jQuery children().fadeOut() 然后执行单个函数
- jQuery是否可以用JavaScript替换文本,然后执行
- 等待几个 ajax 调用完成,然后执行某些操作
- 执行 C# 事件处理程序,然后执行该 js 函数
- JavaScript循环等待一些函数返回,然后执行下一个循环
- AG-Grid 将列标题设置为复选框,然后执行全选或取消全选列,而不是仅组
- 重新加载仅包含脚本的 DIV,然后执行脚本
- 等待几秒钟,让下载完成,然后执行PHP代码
- 使用JQuery在元素中查找文本,然后执行函数
- jQuery:检查元素是否有类,然后执行函数
- Node.js:执行多个异步操作的最佳方式,然后执行其他操作
- 将页面重定向到另一个页面,然后执行jQuery操作
- 检查是否选中任何单选按钮,然后执行代码(多组按钮)
- 加载页面,然后执行javascript