JavaScript中=,==,===之间的区别

本文解析了JavaScript中赋值运算符=与关系运算符==、===的区别,重点讲解了==的类型转换规则和===的严格比较,以及NaN、undefined、null的特殊比较情况,帮助读者掌握这两种运算符的正确使用。

js中的=和==,===是两个不同的概念

在js中我们首先接触到的肯定是 = ,从字面意思我们就可以看出这是一个将等号后面的值赋值给等号前面变量的运算符。而赋值运算符。而=为关系运算符,运算结果为: boolean类型(true/false)
== 叫做判断相等
=== 叫做判断恒等
建议使用===来进行比较判断

== 和 === 的区别

  • 虽然= =和= = =在功能上有着相同点,但是= =的定义非常宽松,可以允许进行类型转换,JavaScript中对象的比较是引用比较,而不是值的比较.对象和其本身是相等的,但是和其他任何对象都不相等.也就是说两个不同的对象有相同的属性名和属性值,他们依然是不相等的."= = ="首先计算其操作的值,然后比较这两个值,比较过程中没有任何类型转换.

=== 规则

在这里插入图片描述

== 的规则与类型转换

在这里插入图片描述
在这里插入图片描述
我相信刚开始接触==时,都会一头雾水,为什么看起来相等结果就是不等,为什么看起来不相等的结果相等.那么就需要更加了解js的= =规则.
在这里我个人总结是:

  • NaN与任何都不等包括它自己;
  • undefined:未定义,如果一个变量只声明但是未赋值,默认值就是undefined
  • null:空值 //null这个值只能手动去设置,一个变量在任何情况下它的值都不会主动是null
  • 在= =中undefined 和 null是相等的
  • 数字优先级最高 其他类型比较时优先转换为number(请熟悉转换为number类型的规则 (NaN) 在这里我就不列出了
  • 布尔与其他比较时,布尔转换为1或0 再比较
  • 对象与非对象比较将对象转换为字符比较
  • 对象之间比较时,根据引用地址比较
    在这里插入图片描述
    在这里插入图片描述
    想要十分轻松的使用= =来进行应用,那就要熟悉js中类型的种类以及相互转换规则
    想知道为什么会导致这样的结果,就要继续学习obj身上究竟携带了哪些方法,在进行隐式转换时,又调用了什么方法进行转换。
### 回答1: 在 JavaScript 中,'==' 和 '===' 都是用于比较两个值是否相等的操作符,它们之间区别在于比较的方式和类型检查。 '==' 操作符会先进行类型转换,再比较两个值是否相等。如果两个值的数据类型不同,'==' 操作符会尝试将它们转换为相同的类型,然后再进行比较。例如,如果比较一个数字和一个字符串,'==' 操作符会将字符串转换为数字,然后再进行比较。这种类型转换可能会导致意外的结果,因此要谨慎使用。 而 '===' 操作符不会进行类型转换,它会严格比较两个值的类型和值是否相等。如果两个值的数据类型不同,'===' 操作符会直接返回 false,不会尝试进行类型转换。 因此,建议在进行比较操作时,优先使用 '===' 操作符,因为它可以避免类型转换带来的风险。只有在确定需要进行类型转换的情况下,才使用 '==' 操作符。 ### 回答2: 在JavaScript中,"=="和"==="两个符号都是用于比较两个值是否相等的运算符。它们的区别在于它们比较两个值时所使用的比较方式和规则不同。 "=="运算符比较值的相等性,它不仅比较值的内容,还会进行一些隐式类型转换。在进行比较时,如果两个操作数类型不同,则会将其一方转换为相同类型,然后再进行比较。例如,如果一个操作数是字符串类型,而另一个是数字类型,那么会将字符串类型的操作数转换为数字类型,然后再进行比较。这种隐式类型转换可能会导致不同数据类型被比较时产生意外的结果。 而"==="运算符比较的是值和类型的完全相等性,它不会进行类型转换。只有当两个操作数既有相同的类型又有相同的值时,才会返回true。因此,在使用"==="运算符进行比较时,需要确保要比较的两个操作数的类型和值都相同。 举个例子,如果我们使用"=="运算符进行比较: ``` 1 == "1" // 返回true,因为"1"被隐式转换为数字1,与操作符另一边的数字1相等 true == 1 // 返回true,因为true被隐式转换为数字1,与操作符另一边的数字1相等 null == undefined // 返回true,因为它们都是无法确定的值 ``` 而使用"==="运算符进行比较: ``` 1 === "1" // 返回false,因为类型不同 true === 1 // 返回false,因为类型不同 null === undefined // 返回false,因为类型不同 ``` 因此,在JavaScript中,我们要根据具体情况选择使用"=="或"==="运算符。一般来说,如果我们需要进行类型检查并且需要确保值和类型都相同的比较,应该使用"==="运算符进行比较;而如果只需要进行简单的值比较,可以使用"=="运算符进行比较。 ### 回答3: JavaScript=====都是比较运算符,用于比较两个值是否相等。但是它们之间有一些差异。 ==(等于)是一种松散的比较运算符,它会自动转换数据类型,然后再比较值是否相等。如果比较的两个值类型不同,它会尝试将它们转换为相同的类型。例如:字符串"5"和数字5在==操作符下会自动转换为数字5,然后判断它们是否相等。这意味着,当使用==操作符时,我们无法控制JavaScript如何将值转换为不同类型,因此可能会导致预期之外的结果。例如: ``` "5" == 5 // true "0" == false // true null == undefined // true ``` ===(全等于)则是一种严格的比较运算符,它要求比较的两个值既要相等,类型也要相同。如果两个值类型不同,它会直接返回false,不会尝试转换类型。这意味着,使用===可以更准确地比较变量的值。例如: ``` "5" === 5 // false "0" === false // false null === undefined // false ``` 总而言之,=====是两个不同的比较运算符,它们在处理变量和值时有很大差异。当我们需要比较值时,建议使用===,以防止产生不必要的错误和预期之外的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MaxLoongLvs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值