泛谈JS逻辑判断选择器 || &&

前言

|| 与 &&在JS里与其它语言不一样,这是选择器运算符,而非逻辑运算符。

对于||来说,若判断为true,则返回第一个值,为false返回第二个值。

&&相反,若判断为 true,则返回第二个,为 false为返回第一个值。

绝对不是像其它语言那样返回true或false,而是会返回第一个值或第二个值。

简单的测试代码

先是true与false的测试,后将false改为数值0. 除了|| 与&&之外易让人疑惑外,JS里的假值表也算是个大疑点。

let A = true;

let B = true;

testLogic(A,B);

A = true;

B = false;

testLogic(A,B);

A = false;

B = true;

testLogic(A,B);

A = false;

B = false;

testLogic(A,B);

/*假值表,以下值 可以被强制布尔转换为false,其它转换皆为true

undefined

null

false

+0,-0,NaN

"" 空字符串

其它皆为真值,如空对象{}

*/

console.log("-----------------next test ---------------");

A = true;

B = true;

testLogic(A,B);

A = true;

B = 0;

testLogic(A,B);

A = 0;

B = true;

testLogic(A,B);

A = 0;

B = 0;

testLogic(A,B);

function testLogic(A,B){

if(A || B){

console.log("A:",A,"B:",B,".A||B true:",A || B);

}

else

{

console.log("A:",A,"B:",B,".A||B flase:",A || B);

}

if(A && B){

console.log("A:",A,"B:",B,".A&&B true:",A || B);

}

else

{

console.log("A:",A,"B:",B,".A&&B flase:",A && B);

}

}

我写代码时我其实就只知道如何做到if 与逻辑判断实现其它语言一样的正常的效果:

结论是保证A与B的是true或false而不是其它值。

正常语言是这样的:

ABA||BA&&B
TTTT
TFTF
FTTF
FFFF

JS语言是这样的:返回的是A或B,只要保证A与B的是true或false而不是其它值,那么在使用上与正常语言逻辑一样。

ABA||BA&&B
TTA(T)B(T)
TFA(T)B(F)
FTB(T)A(F)
FFB(F)A(F)

以上是 泛谈JS逻辑判断选择器 || && 的全部内容, 来源链接: utcz.com/z/360046.html

回到顶部