1、对于string,number等基础类型,==和===是有区别的
1)不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是不等
2)同类型比较,直接进行“值”比较,两者结果一样
2、对于Array,Object等高级类型,==和===是没有区别的
进行“指针地址”比较.所以如果两个值都引用同一个对象或函数,那么==[相等];否则[不相等]。
3、基础类型与高级类型,==和===是有区别的
1)对于==,将高级转化为基础类型,进行“值”比较
2)因为类型不同,===结果为false
4、!=和!==道理同==和===
另外要注意几个特别:
null==undefined;
//true
null==0; //false
undefined==0;
//false
false==0; //true
本文详细解析了JavaScript中基础类型与复杂类型(如Array和Object)之间的等于运算符(== 和 ===)的区别。针对不同情况,文章阐述了这些运算符如何工作,并提供了具体的比较示例。
670

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



