JavaScript ==和===

本文详细解释了JavaScript中“==”与“===”的区别。前者为相等比较,在比较前会进行类型转换;后者为严格相等比较,类型不同时直接返回不相等。文章还介绍了如何使用这些运算符来准确地比较各种类型的值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

== :  值等

=== :恒等(引用等)

ref: http://blog.youkuaiyun.com/wang171838/article/details/8554305

 

JavaScript支持“=”、“==”和“===”运算符。你应当理解这些(赋值、相等、恒等)运算符之间的区别,并在编码过程中小心使用。

         JavaScript对象的比较是引用的比较,而不是值的比较。对象和其本身是相等的,但和其他任何对象都不相等。如果两个不同的对象具有相同数量的属性,相同的属性名和值,它们依然是不相等的。相应位置的数组元素是相等的两个数组也是不相等的。

       严格相等运算符“===”首先计算其操作数的值,然后比较这两个值,比较过程没有任何类型转换:

  • 如果两个值类型不相同,则它们不相等。
  • 如果两个值都是null或者都是undefined,则它们不相等。
  • 如果两个值都是布尔值true或false,则它们相等。
  • 如果其中一个值是NaN,或者两个两个值都是NaN,则它们不相等。NaN和其他任何值都是不相等的,包括它本身!!!通过x!==x来判断x是否为NaN,只有在x为NaN的时候,这个表达式的值才为true。
  • 如果两个值为数字,且数值相等,则它们相等。如果一个为0,另一个为-0,则它们同样相等。
  • 如果两个值为字符串,且所含的对应位上的16位数完全相等,则它们相等。如果它们的长度或内容不同,则它们不等。两个字符串可能含义完全一样且所显示出手字符也一样,但具有不同编码的16位值。JavaScript并不对Unicode进行标准化的转换,因此像这样的字符串通过"==="和"=="运算符的比较结果也不相等。
  • 如果两个引用值同一个对象、数组或函数,则它们是相等的。如果指向不同的对象,则它们是不等的。尽管两个对象具有完全一样的属性。

相等运算符“==”和恒等运算符相似,但相等运算符的比较并不严格。如果两个操作数不是同一类型,那么相等运算符会尝试一些类型转换,然后进行比较:

  •  如果两个操作数的类型相同,则和上文所述的严格相等的比较规则一样。如果严格相等,那么比较结果为相等。如果它们不严格相等,则比较结果为不相等。
  • 如果两个操作数类型不同,“==”相等操作符也可能会认为它们相等。检测相等将会遵守如下规则和类型转换: 
  1. 如果一个值是null,另一个是undefined,则它们相等。
  2. 如果一个值是数字,另一个是字符串,先将字符串转换为数字,然后使用转换后的值比较。
  3. 如果其中一个值是true,则将其转换为1再进行比较。如果其中一个值是false,则将基转换为0再进行比较。
  4. 如果一个值是对象,另一个值是数字或字符串,则将对象转换为原始值,然后再进行比较。对象通过toString()方法或valueOf()方法转换为原始值。JavaScript核心的内置类首先尝试使用valueOf(),再尝试使用toString(),除了日期类,日期类只使用toString()转换。那些不是JavaScript语言核心中的对象则通过各自的实现中定义的方法转换为原始值。
  5. 其他不同类型之间的比较均不相等.

转载于:https://www.cnblogs.com/leenice/p/5233985.html

<think>我们正在讨论JavaScript中的不等于运算符。根据引用[2]引用[5],JavaScript中有两种不等于运算符:`!=`(不等于)`!==`(不全等,也称为严格不等于)。 1. `!=`(不等于):比较两个值是否不相等,如果值不相等则返回true,否则返回false。在比较时,如果两个值类型不同,会尝试进行类型转换,然后再比较值。 - 示例:`1 != 2` 返回true,因为1不等于2;`1 != "1"` 返回false,因为字符串"1"会被转换成数字1,然后比较相等。 2. `!==`(不全等):比较两个值是否不全等,即不仅比较值,还比较类型。如果值或类型中有一个不相等,则返回true,否则返回false。不会进行类型转换。 - 示例:`1 !== '1'` 返回true,因为虽然值相等但类型不同(一个是数字,一个是字符串);`1 !== 2` 返回true,因为值不相等。 引用[2]中提到: - `==`:等于比较,会进行类型转换。 - `===`:全等于比较,数值相等且数据类型相同。 - `!=`:不等于比较,对应`==`的否定。 - `!==`:不全等比较,对应`===`的否定。 引用[5]中也给出了`!=`的示例: ```javascript document.writeln(122 != 12); // 输出true,因为122不等于12 document.writeln("abc" != "abc"); // 输出false,因为两个字符串相等 ``` 因此,在JavaScript中,根据是否需要类型转换,选择使用`!=`或`!==`。通常建议使用`!==``===`,以避免类型转换带来的意外结果。 下面用代码示例说明: ```javascript console.log(1 != 2); // true console.log(1 != "1"); // false,因为类型转换后相等 console.log(1 !== "1"); // true,因为类型不同 console.log(1 !== 1); // false,因为值类型都相同 ``` 相关问题: 1. JavaScript中`==``===`的区别是什么? 2. 为什么在JavaScript中推荐使用严格相等运算符(`===``!==`)? 3. JavaScript中如何进行类型转换?在比较运算符中类型转换的规则是怎样的? 4. 除了不等于运算符,JavaScript还有哪些比较运算符?</think>### JavaScript 不等于运算符详解 在 JavaScript 中,不等于运算符用于比较两个值是否不相等,主要有两种形式: #### 1. `!=`(宽松不等于) - **功能**:比较值是否不相等,会进行类型转换 - **示例**: ```javascript console.log(5 != "5"); // false(类型转换后相等) console.log(5 != 3); // true console.log("hello" != "world"); // true ``` - **特点**:比较前会尝试将操作数转换为相同类型(如字符串转数字) #### 2. `!==`(严格不等于) - **功能**:比较值类型是否不完全相同 - **示例**: ```javascript console.log(5 !== "5"); // true(类型不同) console.log(5 !== 5); // false console.log(null !== undefined); // true ``` - **特点**:不会进行类型转换,要求值类型都不同才返回 true #### 使用建议: 1. 优先使用 `!==` 避免意外的类型转换问题 2. 注意特殊值的比较: ```javascript console.log(NaN != NaN); // true(NaN 不等于任何值) console.log(null != undefined); // false(特殊相等规则) ``` #### 完整示例: ```html <script> // 宽松不等于 console.log(10 != "10"); // false(类型转换后相等) console.log(0 != false); // false(0 false 转换后相等) // 严格不等于 console.log(10 !== "10"); // true(数值 ≠ 字符串) console.log(0 !== false); // true(数值 ≠ 布尔值) </script> ``` > **最佳实践**:在大多数场景下推荐使用严格不等于 `!==`,因为它能避免 JavaScript 自动类型转换带来的意外结果[^2][^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值