条件判断,怎么写

const a = 1
console.log(a === 1 || a ===2)

多个判断条件怎么写,还有其他的书写形式吗

阅读 1.9k
4 个回答

提供一个思路给你.

const a = 1;
const arr = [1,2] //满足条件数组

console.log(arr.includes(a))

例如下面判断奇数偶数的例子:

    var numbuer = 5 ;
    if(numbuer%2!=0){
        document.write("该数为奇数");
    }
    else{
        document.write("该数为偶数");
    }

1
2
3
4
5
6
7
改写为三目表达式时为:

    var numbuer = 5 ;
    document.write("该数为" + numbuer%2!=0 ? "奇数":"偶数");

1
2
但是发现输出结果仅剩一个奇数,这就是运算的优先级问题,出错的原因是 ?的运算优先级比 + 低,所以实际运行的语句是:

    document.write("该数为true" ? "奇数":"偶数");

1
而在JS中,字符串是为真的,所以会输出奇数。

所以上述应改为:

    var numbuer = 5 ;
    document.write("该数为" + (numbuer%2!=0 ? "奇数":"偶数"));

1
2
其中可以记住的是:

不是false, 0, undefined, NaN, “” or null,js都认为是true;

引入:https://blog.csdn.net/weixin_...

第一种if判断

const a = 1;
if (a === 1) {
}

第二种switch

switch(a) {
    case 1:
    case 2:
    break;

    case 3:
    break;

    default:
    break;
}

第三种数组方法

[1, 2, 3].includes(a) ? 'yes' : 'no';
[1, 2, 3].indexOf(a) // 等于-1不存在, 大于-1存在,返回的是该对应的索引值

第四种数组对象,场景类似于获取某个状态; 基于第三种方法的合集;

const status = [
    {key: 1, name: 'success'},
    {key: 2, name: 'error'},
]
const getData = (k = 1) => status.find(item => item.key == k);
const getData2 = (arr = [1, 2]) => status.find(item => arr.includes(item.key));
const getData3 = (k = 1) => status.findIndex(item => item.key == k);
推荐问题
宣传栏