微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

做了一个循环来检查所有inputArrs,但是它只检查第一个

如何解决做了一个循环来检查所有inputArrs,但是它只检查第一个

我做了一个循环来检查所有inputArr元素,但是它只检查第一个元素,如果它是true,则不检查其他元素并返回true。我需要检查所有它们,如果它们中的任何一个为假,则希望得到一条错误消息。我也尝试过forEach,但仍然无法正常工作

这是我的代码


btn.addEventListener('click',function () {
    let isValid = checkIfValid([firstName,surname,email,mobileNumber])
    let userInfo = generateInputs(firstName.value,surname.value,email.value,mobileNumber.value);
    if (isValid) {
     console.log('all checked')
    } else {
     console.log('you need to fill all fields')
    }
})


function checkIfValid(inputArr) {
    for (let i = 0; i < inputArr.length; i++) {
        if (inputArr[i].value === '') {
            return false
        } else {
            console.log(inputArr[i].value)
            return true
        }
    }
}

解决方法

您的return true语句停止for循环。

这将起作用,在第一个无效项目上返回false,否则返回true:

function checkIfValid(inputArr) {
    for (let i = 0; i < inputArr.length; i++) {
        if (inputArr[i].value === '') {
            return false
        } else {
            console.log(inputArr[i].value)
        }
    }
    return true
}

现代替代方案

您可以使用Array.prototype.every()来简化代码:

function checkIfValid(inputArr) {
    return inputArr.every(el => el.value !== '');
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。