JavaScript 比较 和 逻辑运算符
在 JavaScript 中,比较和逻辑运算符用于处理数据的比较和逻辑判断。它们是编程中最基本且最常用的工具之一。以下是对这些运算符的详细解释和示例:
一 比较运算符(Comparison Operators)
比较运算符用于比较两个值,并返回一个布尔值(true 或 false)。
1 相等运算符
比较两个值是否相等,执行类型转换(如果需要)。
例如:5 == ‘5’ 结果为 true,因为 ‘5’ 被转换为数字 5。
示例:
console.log(5 == '5'); // 输出: true
2 全等运算符
比较两个值是否相等,不执行类型转换。
例如:5 === ‘5’ 结果为 false,因为 5 是数字,而 ‘5’ 是字符串。
示例:
console.log(5 === '5'); // 输出: false
3 不等运算符 !
比较两个值是否不相等,执行类型转换(如果需要)。
例如:5 != ‘5’ 结果为 false,因为 ‘5’ 被转换为数字 5,它们相等。
示例:
console.log(5 != '5'); // 输出: false
4 不全等运算符 !
比较两个值是否不相等,不执行类型转换。
例如:5 !== ‘5’ 结果为 true,因为 5 是数字,而 ‘5’ 是字符串。
示例:
console.log(5 !== '5'); // 输出: true
5 大于运算符 >
比较左边的值是否大于右边的值。
例如:10 > 5 结果为 true。
示例:
console.log(10 > 5); // 输出: true
6 小于运算符 <
比较左边的值是否小于右边的值。
例如:5 < 10 结果为 true。
示例:
console.log(5 < 10); // 输出: true
7 大于等于运算符 >
比较左边的值是否大于或等于右边的值。
例如:10 >= 10 结果为 true。
示例:
console.log(10 >= 10); // 输出: true
8 小于等于运算符 <
比较左边的值是否小于或等于右边的值。
例如:5 <= 10 结果为 true。
示例:
console.log(5 <= 10); // 输出: true
二 逻辑运算符(Logical Operators)
逻辑运算符用于对布尔值进行逻辑操作,并返回一个布尔值。
1 与运算符 &&
如果两个操作数都为 true,则返回 true,否则返回 false。
常用于多条件判断。
示例:
console.log(true && true); // 输出: true
console.log(true && false); // 输出: false
2 或运算符 ||
如果任意一个操作数为 true,则返回 true,如果两个操作数都为 false,则返回 false。常用于选择其中一个条件满足即可的情况。
示例:
console.log(true || false); // 输出: true
console.log(false || false); // 输出: false
3 非运算符 !
反转布尔值。如果值为 true,则返回 false;如果值为 false,则返回 true。 常用于布尔值的取反。
示例:
console.log(!true); // 输出: false
console.log(!false); // 输出: true
4 逻辑与赋值运算符 &&
对变量应用逻辑与操作,并赋值给变量本身。
例如:x &&= y 等同于 x = x && y。
示例:
let x = true;
x &&= false; // x 现在是 false
console.log(x); // 输出: false
5 逻辑或赋值运算符 ||
对变量应用逻辑或操作,并赋值给变量本身。
例如:x ||= y 等同于 x = x || y。
示例:
let x = false;
x ||= true; // x 现在是 true
console.log(x); // 输出: true
6 逻辑异或运算符 ^(不直接作为逻辑运算符使用,但有逻辑含义)
在布尔上下文中,它用于检查两个布尔值是否不同。结果为 true 当且仅当两个值不同。
例如:true ^ false 结果为 true。
示例:
console.log(true ^ false); // 输出: true
console.log(true ^ true); // 输出: false
三 总结
比较运算符 用于比较两个值,决定它们的相对大小或是否相等。
逻辑运算符 用于处理布尔值的逻辑操作,例如与、或、非等。