javascript ==和===的区别

== equality 等同,=== identity 恒等。

==, 两边值类型不同的时候,要先进行类型转换,再比较。
===,不做类型转换,类型不同的一定不等。

下面分别说明:
先说 ===,这个比较简单。下面的规则用来判断两个值是否===相等:
1、如果类型不同,就[不相等]
2、如果两个都是数值,并且是同一个值,那么[相等];(!例外)的是,如果其中至少一个是NaN,那么[不相等]。(判断一个值是否是NaN,只能用isNaN()来判断)
3、如果两个都是字符串,每个位置的字符都一样,那么[相等];否则[不相等]。
4、如果两个值都是true,或者都是false,那么[相等]。
5、如果两个值都引用同一个对象或函数,那么[相等];否则[不相等]。
6、如果两个值都是null,或者都是undefined,那么[相等]。
再说 ==,根据以下规则:
1、如果两个值类型相同,进行 === 比较。
2、如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较:
a、如果一个是null、一个是undefined,那么[相等]。
b、如果一个是字符串,一个是数值,把字符串转换成数值再进行比较。
c、如果任一值是 true,把它转换成 1 再比较;如果任一值是 false,把它转换成 0 再比较。
d、如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。 js核心内置类,会尝试valueOf先于toString;例外的是Date,Date利用的是toString转换。非js核心的对象,令说(比较麻 烦,我也不大懂)
e、任何其他组合,都[不相等]。

举例:
"1" == true
类型不等,true会先转换成数值 1,现在变成 "1" == 1,再把"1"转换成 1,比较 1 == 1, 相等。

= 赋值运算符
== 等于
=== 严格等于
例:
var a = 3;
var b = "3";

a==b 返回 true
a===b 返回 false

因为a,b的类型不一样
===用来进行严格的比较判断

### JavaScript 中 `==` `===` 运算符的区别JavaScript 中,`==` 被称为抽象相等运算符,而 `===` 则被称为严格相等运算符。两者的差异主要体现在类型转换上。 当使用 `==` 比较两个值时,如果它们的类型不同,则会尝试进行隐式的类型转换再做比较[^1]。这意味着,在某些情况下,即使数值相同但数据类型不同的变量也会被认为是相等的。例如: ```javascript console.log(0 == ""); // 输出: true console.log('0' == 0); // 输出: true ``` 相比之下,`===` 不仅检查值是否相等,还会验证这两个操作数的数据类型是否一致。只有当两者都匹配时才会返回 `true`;否则就返回 `false`[^2]。因此下面的例子都会得到 `false` 的结果: ```javascript console.log(0 === ""); // 输出: false console.log('0' === 0); // 输出: false ``` 对于不等于的情况也存在类似的差别:`!=` 只关心最终计算后的值而不考虑原始类型的差异,但是 `!==` 同样会在检测到不同类型的情况下立即判定为假并给出相应的布尔值响应[^3]。 为了编写更清晰、可预测性强以及错误率更低的代码,建议尽可能多地采用严格的比较方式即 `===` 来代替宽松版本 `==`[^4]。 #### 实际应用中的例子 这里有一个简单的函数用来展示这两种运算符的行为: ```javascript function compareValues(a, b) { console.log(`Using '==' : ${a == b}`); console.log(`Using '===': ${a === b}\n`); } compareValues(5, "5"); // Using '==' : true // Using '===': false compareValues(true, 1); // Using '==' : true // Using '===': false compareValues(null, undefined); // Using '==' : true // Using '===': false ``` 通过上述实例可以看出,在处理可能涉及多种数据类型的场景下,选择合适的相等性判断方法是非常重要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值