JavaScript == 与 === 区别
1、对于 string、number 等基础类型,== 和 === 是有区别的
• a)不同类型间比较,== 之比较 “转化成同一类型后的值” 看 “值” 是否相等,===
如果类型不同,其结果就是不等。
• b)同类型比较,直接进行 “值” 比较,两者结果一样。
2、对于 Array,Object 等高级类型,== 和 === 是没有区别的
进行 “指针地址” 比较
3、基础类型与高级类型,== 和 === 是有区别的
• a)对于 ==,将高级转化为基础类型,进行 “值” 比较
• b)因为类型不同,=== 结果为 false
4、!= 为 == 的非运算,!== 为 === 的非运算
好了,让我们来看检验一下:
var num=1;
var str="1";
var test=1;
test == num //true 相同类型 相同值
test === num
//true 相同类型 相同值
test !== num
//false test与num类型相同,其值也相同, 非运算肯定是false
num == str
//true把str转换为数字,检查其是否相等。
num != str
//false == 的 非运算
num === str false
类型不同,直接返回false
num !== str
//true num 与 str类型不同,意味着其两者不等 非运算自然是true啦
好啦,到这里,=和的区别你懂了吗?
本文详细解析了JavaScript中==与===运算符的区别,包括基础类型、高级类型间的比较规则,以及非运算的处理方式。通过具体示例展示了不同场景下运算符的行为差异。

被折叠的 条评论
为什么被折叠?



