欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

浅谈javascript中的 “ && ” 和 “ || ”

程序员文章站 2022-06-01 14:51:47
有时候,我们会在jquery框架或者其他js插件中发现里面有很多 “ && ” 和 “ || ”,那么这两个标识到底是什么含义?怎么使用?我觉得还是有必要稍微深究一下。...

有时候,我们会在jquery框架或者其他js插件中发现里面有很多 “ && ” 和 “ || ”,那么这两个标识到底是什么含义?怎么使用?我觉得还是有必要稍微深究一下。

一、原理:

&& 操作符特点:逻辑运算表达式中只要一个是false就取false的值,都是true取后面,都是false取前面。

|| 操作符特点:逻辑运算表达式中只要一个是true就取true的值,都是true取前面,都是false取后面。

在js逻辑运算中,我们知道 0、""、null、false、undefined、nan 这五种数据类型是会被判断为false的。那么,我们在进行js的逻辑运算过程中,就可以根据上面的原理以及这五种数据类型来进行相应的判断处理。直接上demo...

二、原始demo:

先亮出问题!!!

如果我们要根据学生的成绩来判断等级,比如:90分表示a,80分表示b,60分表示c,其他表示d。

那么我们可以这么做:

js代码:

var score = 90;
var grade = '';
if(score === 90){
 grade = "a";
}else if(score === 80){
 grade = "b";
}else if(score === 60){
 grade = "c";
}else{
 grade = "d";
}
console.log("当前学生等级为:" + grade); // 当前学生等级为:a

或者这样:

var score = 90;
var grade = '';
switch(score){
 case 90:
 grade = "a";
 break;
 case 80:
 grade = "b";
 break;
 case 60:
 grade = "c";
 break;
 default:
 grade = "d";
 break;
};
console.log("当前学生等级为:" + grade); // 当前学生等级为:a

三、优化demo:

其实,如果我们用 “ && ” 和 “ || ” 的话,大可不必如上面那么麻烦。

var score = 90;
var grade = (score===90 && 'a') || (score===80 && 'b') || (score===60 && 'c') || 'd';
console.log("当前学生等级为:" + grade); // 当前学生等级为:a

上面代码可以这么理解:

如果score的值等于90,那么score===90的逻辑表达式就成立(也即是true),就会执行到后面 'a' 的赋值操作,同时后面的“||” 逻辑运算也可以忽略(因为“||”运算符的特点是前面一旦为true,后面就没有执行的必要了)。

如果score的值不等于90,那么score===90的逻辑表达式就不成立(也即是false),根据“&&”操作符的特点,我们知道“(score===90 && 'a')”这段代码就不会执行到后面 'a' 的赋值操作,同时由于“(score===90 && 'a')”这段代码整体是false,那么根据“||”的特点,整个逻辑表达式会继续往后执行。

以此类推,如果前面所有的逻辑表达式都不成立,那么根据“||”的特点(全部为false就取最后面的),最后的grade赋值就会是“d”。

我们还可以用json形式来处理上面的逻辑运算:

var score = 90;
var grade = {90:"a", 80:"b", 60:"c"}[score] || 'd';
console.log("当前学生等级为:" + grade); // 当前学生等级为:a

这里利用了json对象的属性读取,当“json对象.属性值”存在的时候(为true),就会取得对应属性的key值(a、b或者c)。当score属性值不存在与json对象中的时候,就会执行“||”后面的内容,也就是把grade赋值为“d”。

当然,我们会发现上面的数值比较并没有太大的实用性,比如当学生的成绩在85分的时候,等级也会变成“d”,这明显是不合适的!!!

所以我们可以把上面的代码再优化下,把数值的 “相等比较” 改成 “范围区间比较” 。

var score = 85;
var grade = (score>=90 && 'a') || (score>=80 && 'b') || (score>=60 && 'c') || 'd';
console.log("当前学生等级为:" + grade); // 当前学生等级为:b

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!