在JavaScipt中==(相等)和===(严格相等,strick equality 也有译作“恒等”、“全等”)用于比较两个值是否相等,两个运算符允许任意类型的操作数。如果操作数相等则返回true,否则返回false。===也称作严格相等运算符,它用来检测两个操作数是否严格相等。==运算符称作相等运算符,它用来检测两个操作数是否相等,这里“相等”的定义非常宽松,可以允许进行类型转换。
=赋值
==相等
===严格相等
!=(不相等)和!==(不严格相等)运算符的检测是==和===运算符的求反。如果两个值通过==的比较结果是true,那么通过!=的比较结果就是false。如果两个值通过===的比较结果是true,那么通过!==的比较结果为false。
JavaScript对象的比较是引用的比较,而不是值的比较。对象和其本身是相等的,但是和其他任何对象都不相等。如果两个不同的对象具有相同数量的属性,相同的属性名和值,它们依然是不相等的。相应位置的数组元素是相等的两个数组也是不相等的。

对象

var objA = { a: 1, b: 2, b: 3 };
var objB = { a: 1, b: 2, b: 3 };
objA == objB;//=>false,数组arrA和数组arrB不相等

数组

 var a=[1,2,3,4,5];
var b=[1,2,3,4,5];
a==b;//=>false,数组a和数组b不相等。

严格相等运算符===首先计算其操作数的值,然后比较这两个值,比较过程中没有任何类型转换:
(1)如果两个值的类型不同,则它们不严格相等(即严格相等不成立)。
(2)如果两个值都是null或是undefined,则它们不严格相等。
(3)如果两个值都是布尔值true或者都是布尔值false,则它们严格相等。
(4)如果其中一个值是NaN,或者两个值都是NaN,则它们不严格相等。NaN和其他任何值都是不相等的,包括它本身!通过x!==x来判断X是否为NaN,只有在x为NaN的时候,这个表达式的值才为true。
(5)如果两个值为字符串,且所含的对应位上的16位数完全相等,则它们相等。如果它们长度或内容不同,则它们不等。两个字符串可能含义完全一样且所显示出的字符也一样,但是具有不同编码的16位值。JavaScript并不对Unicode进行标准化的转换,因此像这样的字符串通过===和==元素安抚的比较结果也不相等。
[相关阅读:JavaScript中什么是16位数?]
(6)如果两个引用值指向同一个对象、数组和函数,则它们是严格相等的,如果指向不同的对象,则它们是不严格相等,尽管两个对象具有完全一样的属性。

相等运算符==和恒等运算符相似,但相等运算符的比较并不严格。如果两个操作数不是同一类型,那么相等运算符会尝试进行一些类型转换,然后进行比较:
(1)如果两个操作数的类型相同,则和上文所述的严格相等比较规则一样。如果严格相等,那么比较结果为相等。
(2)如果两个操作数类型不同,==相等操作符也可能会认为他们相等。检测相等将会遵循如下规则和类型转换:
Ⅰ如果一个值是null,另一个是undefined,则它们相等。
Ⅱ如果一个值是数字,另一个是字符串,先将字符串转换为数字,然后使用转换后的值进行比较。
Ⅲ如果其中一个值是true,则将其转换为1再进行比较。如果其中一个值是false,则将其转换为0再进行比较。
Ⅳ如果其中一个值是对象,另一个值是数字或字符串,则通过转换规则将对象转换为原始值,然后再进行比较。对象通过toString()方法或者valueOf()方法转换为原始值。JavaScript语言核心的内置类首先尝试使用valueOf(),再尝试使用toString(),除了日期类、日期类只使用toString()转换。那些不是JavaScript语言核心中的对象则是通过各自的实现中定义的方法转换为原始值。
[相关阅读:JavaScript对象转换为原始值的规则]
Ⅴ其他不同类型之间的比较均不相等。

 "1"==true;//=>true,相等成立

这个表达式的结果是true,这表明完全不同类型的值比较结果为相等。布尔值true首先转换为数字1,然后再执行比较。接下来字符串"1"也转换成了数字1,因为两个数字的值相等,因此比较结果为true。

JavaScript中相等==和严格相等===的区别的更多相关文章

  1. JavaScript中const、var和let区别浅析

    在JavaScript中有三种声明变量的方式:var.let.const.下文给大家介绍js中三种定义变量的方式const, var, let的区别. 1.const定义的变量不可以修改,而且必须初始 ...

  2. JavaScript中值类型和引用类型的区别

    JavaScript的数据类型分为两类:原始类型和对象类型.其中,原始类型包括:数字.字符串和布尔值.此外,JavaScript中还有两个特殊的原始值:null和undefined,它们既不是数字也不 ...

  3. JavaScript中=、==、===以及!=、!==的区别与联系

    JavaScript中=.==.===以及!=.!==的区别与联系   在JavaScript中,“=”代表赋值操作:“==”先转换类型再比较,“===”先判断类型,如果不是同一类型直接为false. ...

  4. JavaScript中object和Object有什么区别

    JavaScript中object和Object有什么区别,为什么用typeof检测对象,返回object,而用instanceof 必须要接Object呢 ————————————————————— ...

  5. 深入理解Javascript中构造函数和原型对象的区别

    在 Javascript中prototype属性的详解 这篇文章中,详细介绍了构造函数的缺点以及原型(prototype),原型链(prototype chain),构造函数(constructor) ...

  6. 关于javascript中apply()和call()方法的区别

    如果没接触过动态语言,以编译型语言的思维方式去理解javaScript将会有种神奇而怪异的感觉,因为意识上往往不可能的事偏偏就发生了,甚至觉得不可理喻.如果在学JavaScript这自由而变幻无穷的语 ...

  7. javascript 中 offsetWidth,clientWidth;offsetHeight,clientHeight的区别

    javascript 中 offsetWidth 是对象的可见宽度,包滚动条等边线,会随窗口的显示大小改变 clientWidth.offsetWidth.clientHeight区别IE6.0.FF ...

  8. 在 JavaScript 中 prototype 和 __proto__ 有什么区别

    本文主要讲三个 问题 prototype 和 proto function 和 object new 到底发生了什么 prototype 和 proto 首先我们说下在 JS 中,常常让我们感到困惑的 ...

  9. javascript中的undefined与null的区别

    一.相似性 在JavaScript中,将一个变量赋值为undefined或null,老实说,几乎没区别. var a = undefined; var a = null; 上面代码中,a变量分别被赋值 ...

  10. javascript中常见undefined与defined的区别

    在JavaScript中相信“undefined”与“defined”对大家来说都肯定不陌生,但是又不是很清楚它们的区别,先看两个demo我们再说, 例1. console.log(parms); / ...

随机推荐

  1. WIndows 系统下的常用命令 和 检测方法

    ### 一.检测硬盘速度(Windows 自带工具) #### 使用windows 系统自带的工具测试硬盘读写速度 > 在使用下面命令前,需要获得管理员权限,才会在Dos窗口上显示(否则,一闪而 ...

  2. [Algorithm] 9. Two Sum

    Description Given an array of integers, return indices of the two numbers such that they add up to a ...

  3. java 十三周总结

  4. 版本优化-test

    版本优化 标签(空格分隔): 测试 需求经手人太多,直接提bug,开发不乐意,跟Leader确认不靠谱,跟PM确认,不熟悉流程,跟第三方PM确认靠谱了,结果被开发三言两语,变成了不改bug 而改需求 ...

  5. Mac安装virtualwrapper时报错No module named virtualenvwrapper

    1. 前言 我在使用mac安装virtualwrapper的时候遇到了问题,搞了好长时间,才弄好,在这里总结一下分享出来,供遇到相同的问题的朋友使用,少走些弯路. 2. 问题说明 Mac默认系统的py ...

  6. python之cookbook-day01

    第一章:数据结构和算法 1.1 解压序列赋值给多个变量 >>> p = (4, 5) >>> x, y = p >>> x 4 >>& ...

  7. RequestMapping_请求参数&请求头

    params和headers支持简单的表达式: --param1:表示请求必须包含名为param1的请求参数. --!param1:表示请求不能包含名为param1的请求参数. --param1 != ...

  8. HDU 1573 解同余模线性方程组

    题目意思很直接就是一道裸的解线性同余模方程组的题目 #include <cstdio> #include <cstring> using namespace std; #def ...

  9. 旅游电车(cogs 1175)

    [问题描述] Henryy国正致力于首都的一个旅游电车建设工程.首都有N个旅游景区.Henryy国的电车永远只沿道路规定的方向行驶,为了不使投入使用的电车有可能无法回到它的起始站,Henryy希望知道 ...

  10. 【BZOJ4398】福慧双修(二进制,最短路)

    题意: 此题中S=1 思路:Orz ManGod秒切此题 我觉得出入边权互换不太直观,就改了一下写法 第一次默认与1有关的第一条出边只出不入,第二次默认只入不出 ..]of longint; head ...