本文介绍: JavaScript一个便利之处在于,它会自动将布尔上下文引用的任何值强制布尔值。但在有些情况下,这可能会让人困惑,因为它很方便。例如,下面的一些情况对许多JavaScript开发者来说是很麻烦的。正如这些例子所表明的,类型强制规则有时非常清楚。因此,除非明确需要类型强制,否则最好使用。实际上都是对象,任何对象在JavaScript中都会被强制布尔值。关于最后两个,尽管是空的(大家可能会觉得他们false),),以避免强制类型转换的带来非预期的副作用。,这与ECMA-262规范一致。

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

// 下面结果都是 'true'
console.log(false == '0');
console.log(null == undefined);
console.log(" trn" == 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

原文地址:https://blog.csdn.net/dxn16638400024/article/details/134762964

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_37380.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注