
文章插图
【JS 中令人脑壳疼的 == 与 === 区别到底是什么?】曾经对我来说 , 等于就是等于 , 所以第一次接触到 JS 中的三等号时我感到很困惑 。大部分编程语言中都有双等号"==" , 但没有三等号"===" 。
下面是一个比较官方的双等号与三等号的差别:
"如果需要判断运算数是否为同一类型并且值相等 , 则使用严格相等运算符[===] 。
否则 , 使用标准相等运算符[==] , 它允许你比较两个运算数的值 , 即使它们类型不同 。"
--MDN web docs
在认为理解它的关键就在于了解“类型强制转换” , 它是“动态类型语言” Vanilla JAVAScript 中的一个奇怪的概念 。
之所以会有类型强制转换是因为 JS 想要防御编程错误 , 比如拿一个数字和一个字符串比较:
“当在 JavaScript 中使用双等号时我们测试的是不严格的相等 。双等号还会带来类型强制转换 。
强制转换的意思是只有当运算数被转换为相同类型时它们才能被比较 。”
换句话说 , 由于有类型转换 , 不同类型的值可以通过 == 被比较 , 但一个字符串和一个数字则永远不会用 === 严格相等 。
举个例子:
console.log(Number("7") - 7 == 0); // trueconsole.log(Number("7") - 7 === 0); // trueconsole.log(Number("7") - 7 === Number("0")); // trueconsole.log("7" - 7 == "0"); // trueconsole.log("7" - 7 === "0"); // false
JavaScript 中的真与假
在 JavaScript 中我们有六个代表假的值:false, 0, ""(空字符串),null, undefined 和 NaN(Not A Number) , 这六个假值互相是什么关系呢?
“将 false , 0和""用(==)相比较 , 结果为真 , 它们都不严格相等;null 和 undefined 只和自己相等;NaN 不与任何假值相等 , 包括它自己 。”
// All permutations of falsy comparisons in JavaScript by Dr. Derek Austin console.log(false == false); // trueconsole.log(false === false); // trueconsole.log(false == 0); // true -- false, 0, and "" are loosely equalconsole.log(false === 0); // falseconsole.log(false == ""); // true -- false, 0, and "" are loosely equalconsole.log(false === ""); // falseconsole.log(false == null); // falseconsole.log(false === null); // falseconsole.log(false == undefined); // falseconsole.log(false === undefined); // falseconsole.log(false == NaN); // falseconsole.log(false === NaN); // falseconsole.log(0 == 0); // trueconsole.log(0 === 0); // trueconsole.log(0 == ""); // true -- false, 0, and "" are loosely equalconsole.log(0 === ""); // falseconsole.log(0 == null); // falseconsole.log(0 === null); // falseconsole.log(0 == undefined); // falseconsole.log(0 === undefined); // falseconsole.log(0 == NaN); // falseconsole.log(0 === NaN); // falseconsole.log("" == ""); // trueconsole.log("" === ""); // trueconsole.log("" == null); // falseconsole.log("" === null); // falseconsole.log("" == undefined); // falseconsole.log("" === undefined); // falseconsole.log("" == NaN); // falseconsole.log("" === NaN); // falseconsole.log(null == null); // trueconsole.log(null === null); // trueconsole.log(null == undefined); // true -- null loosely equals undefinedconsole.log(null === undefined); // falseconsole.log(null == NaN); // falseconsole.log(null === NaN); // falseconsole.log(undefined == undefined); // trueconsole.log(undefined === undefined); // trueconsole.log(undefined == NaN); // falseconsole.log(undefined === NaN); // falseconsole.log(NaN == NaN); // false -- NaN nothing equals NaN, andconsole.log(NaN === NaN); // false -- NaN doesn't equal itself
虽然 JS 中的假值这么奇葩 , 但幸好除了这些假值以外所有值都为真:
“在 JavaScript 中 , 真值就是在布尔类型上下文中所有被认为是"true"的值 。所有的值皆为真 , 除非它被定义为假 , 比如 false , 0 , "" , null , undefined 和 NaN 。”
ECMAScript 中的情况呢?
如果你感兴趣的话 , 下面是 JavaScript 所使用的具体算法 。
严格相等运算符
严格相等运算符(=== 与 !==)使用严格相等比较算法来比较两个运算数:
推荐阅读
-
赵文卓|张恒爆料郑爽指使粉丝剪辑录音,白用法务不出钱,占便宜已成习惯
-
SN|SN的S10世界赛:步步血泪!战胜TES绝非偶然,这些你注意了吗?
-
「交通运输部」交通运输部:明天起 乘坐地铁这10类行为坚决禁止
-
球球爱看娱乐|杨紫曝真相:自己跟他拍戏很受刺激,新顶流罗云熙瘦到脱相
-
龙之队|只看营收!华为公司对比三星集团,差距有多大?,抛开情怀
-
gzxzjx|小时候被扮女孩的男星,王源可爱,吴磊淑女,看到金瀚:白活了
-
-
『幸福树』想让幸福树一辈子不黄叶,春天要记得做几件事,效果真不赖!
-
#文化湖州#云美食 | 小编带你体验“湖州味道”?双林姑嫂饼
-
-
漂亮:3个步骤4段动画,教你在Excel中制作漂亮的WiFi信号图表,
-
央行|央行续作MLF量增价稳 8月LPR下调概率降低
-
-
世卫组织总干事称:中国新冠肺炎新确诊病例数量已趋于稳定
-
今年国庆打算去东南亚国家旅游,有啥推荐泰国感觉国人泛滥了,菲律宾马来西亚咋样
-
海天味极鲜酱油《非诚勿扰》闺蜜和男朋友吵架,劝分还是劝和
-
迁安|年入1200亿!月活用户超7亿!马云为实控人!超级巨无霸蚂蚁集团递交招股书
-
恒大汽车电池研发有多强?幕后班底曝光超800人科研团队
-
北京仅剩4个中风险地区|北京仅剩4个中风险地区 疫情终于有所缓解
-
有态度的车|值不值得买?维修师傅一语道破其中“玄机”,5万一台的泡水豪车