双等号的困惑(js的问题)

简介: 双等号的困惑(js的问题)

JavaScript 的一个便利之处在于,它会自动将布尔上下文中引用的任何值强制为布尔值。但在有些情况下,这可能会让人困惑,因为它很方便。例如,下面的一些情况对许多JavaScript开发者来说是很麻烦的。

// 下面结果都是 'true'
console.log(false == '0');
console.log(null == undefined);
console.log(" \t\r\n" == 0);
console.log('' == 0);
 
// 下面也都成立
if ({}) // ...
if ([]) // ...

关于最后两个,尽管是空的(大家可能会觉得他们是 false),{}和[]实际上都是对象,任何对象在JavaScript中都会被强制为布尔值 "true",这与ECMA-262规范一致。


正如这些例子所表明的,类型强制的规则有时非常清楚。因此,除非明确需要类型强制,否则最好使用===和!==(而不是==和!=),以避免强制类型转换的带来非预期的副作用。(== 和 != 会自动进行类型转换,而 === 和 !== 则相反)


另外需要注意的是:将NaN与任何东西(甚至是NaN)进行比较时结果都是 false。因此,不能使用双等运算符(==, ==, !=, !==)来确定一个值是否是NaN。如果需要,可以使用内置的全局 isNaN()函数。

console.log(NaN == NaN);    // False
console.log(NaN === NaN);   // False
console.log(isNaN(NaN));    // True
相关文章
|
6月前
|
移动开发 JSON JavaScript
分享188个JS图片效果JS代码,总有一款适合你
分享188个JS图片效果JS代码,总有一款适合你
85 1
|
5月前
|
JavaScript iOS开发
js常用的代码有哪些 老司机带你来看看
js常用的一些代码分享给大家
32 4
|
6月前
|
JavaScript 前端开发 Java
前端知识点03(JS)
前端知识点概览:了解JS中的this指向,包括全局、函数、new、apply/call/bind及箭头函数的规则。理解script的async和defer属性对脚本加载和执行的影响。探讨setTimeout和setInterval的用法及其在性能上的考量。ES6与ES5的区别在于新语法特性,如let/const、箭头函数、模板字符串、模块化、类和继承等。此外,ES6还引入了Symbol、解构赋值、默认参数、Map/Set和Generator等功能。别忘了点赞和支持作者哦!
53 1
|
6月前
|
存储 JSON JavaScript
js必备知识小结(二)
js必备知识小结(二)
39 0
|
6月前
|
存储 JavaScript 前端开发
js必备知识小结(一)
js必备知识小结(一)
35 0
|
JavaScript 中间件 关系型数据库
js编程时常见问题解决方法
js编程时常见问题解决方法
js编程时常见问题解决方法
|
JavaScript
一道JS题,让我更深刻的理解了JS的执行机制
闲逛摸鱼发现一道有趣的题,题目如下,本来是不想拿出来单独写一篇文章的,因为太短了,但是我需要存在感,沸点没人看,所以还是写一篇文章吧;
76 0
一道JS题,让我更深刻的理解了JS的执行机制
|
JavaScript 前端开发 算法
js基础,我来帮你
js基础,我来帮你
88 0
js基础,我来帮你
|
存储 JavaScript 前端开发
重温js——js语法基础
在变量声明这里,大家肯定还记得。所有的js 在使用的时候需要进行声明。也就是在内存地址中开辟一个空间。然后等待数据的"入住"
重温js——js语法基础
下一篇
无影云桌面