js中==与===的区别

╰半橙微兮° 2022-09-23 10:48 386阅读 0赞

在js中,我们有时会遇到==和===的问题,下面我就来介绍这两个的区别:

1、对于string,number等基础类型,==和===是有区别的
(1)不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是不等
(2)同类型比较,直接进行“值”比较,两者结果一样

2、对于Array,Object等高级类型,==和===是没有区别的,进行的都是”指针地址”比较,是相同的。

3、基础类型与高级类型,==和===是有区别的
(1)对于==,将高级转化为基础类型,进行“值”比较
(2)因为类型不同,===结果为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

5、总结:双等号会造成类型转换,推荐一律使用三等号
== 和 != 比较若类型不同,先偿试转换类型,再作值比较,最后返回值比较结果 。而 === 和 !== 只有在相同类型下,才会比较其值

发表评论

表情:
评论列表 (有 0 条评论,386人围观)

还没有评论,来说两句吧...

相关阅读

    相关 js=====区别

    对于string,number等基础类型,==和===是有区别的 不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是

    相关 Jsempx区别

    em指字体高,任意浏览器的默认字体高都是16px。所以未设置的浏览器都符合: 1em=16px。那么10px=0.625em,12px=0.75em。如果你要为了简易操作,可以

    相关 JS === == 区别

     确认两个变量是否相等是编程中的一个非常重要的操作。尤其是涉及到对象的比较时。为此,JS 提供了两组操作符。 1、相等和不相等。(== 与 !=)