首页 > 解决方案 > javascript if语句多个运算符失败

问题描述

我有一个评估的 if 语句

if(expression || expression &&
   expression || expression){

   //logic
} 

由于我无法理解的原因,and 运算符之后的 else 语句没有得到评估。if 语句有一些我不知道的规则吗?

这是我的代码:

const fillTable = function (array) {
    let tbody = document.querySelector("#tblbody");
    while (tbody.firstChild) {
        tbody.removeChild(tbody.firstChild);
    }
    array.forEach(element => {
        let region = regionOption.options[regionOption.selectedIndex].value;
        let gender = genderOption.options[regionOption.selectedIndex].value;
        elementGender = Object.values(element)[2];
        elementRegion = Object.values(element)[3];
        console.log(elementRegion + "+" + region);
        console.log(elementGender + "+" + gender);

        if (elementRegion === region || region === "All" &&
            elementGender === gender || gender === "bot") {
            let tr = document.createElement("tr");
            tbody.appendChild(tr);
            const values = Object.values(element);
            values.forEach(element => {
                let td = document.createElement("td");
                td.appendChild(document.createTextNode(element));
                tr.appendChild(td);
            })
        }
    })
};

即使 if 语句中的性别不匹配,循环也会继续。

标签: javascriptif-statementoperators

解决方案


看起来if条件中的 2 行都应该在它们自己的分组运算符中:

if (
       (expression1 || expression2)
    && (expression3 || expression4)
) {
    // ...
} 

推荐阅读