泛谈JS逻辑判断选择器 || &&
Posted tacatno
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了泛谈JS逻辑判断选择器 || &&相关的知识,希望对你有一定的参考价值。
前言
|| 与 &&在JS里与其它语言不一样,这是选择器运算符,而非逻辑运算符。
对于||来说,若判断为true,则返回第一个值,为false返回第二个值。
&&相反,若判断为 true,则返回第二个,为 false为返回第一个值。
绝对不是像其它语言那样返回true或false,而是会返回第一个值或第二个值。
简单的测试代码
先是true与false的测试,后将false改为数值0. 除了|| 与&&之外易让人疑惑外,JS里的假值表也算是个大疑点。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
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而不是其它值。
正常语言是这样的:
A | B | A||B | A&&B |
T | T | T | T |
T | F | T | F |
F | T | T | F |
F | F | F | F |
JS语言是这样的:返回的是A或B,只要保证A与B的是true或false而不是其它值,那么在使用上与正常语言逻辑一样。
A | B | A||B | A&&B |
T | T | A(T) | B(T) |
T | F | A(T) | B(F) |
F | T | B(T) | A(F) |
F | F | B(F) | A(F) |
以上是关于泛谈JS逻辑判断选择器 || &&的主要内容,如果未能解决你的问题,请参考以下文章
JavaScriptJavaScript赋值语句中的逻辑与&&和逻辑或||
JS ECMAScript 5中的every 和 some方法进行逻辑判断