Javascript:比较为null – !== vs!=

好的,所以我在使用node.js应用程序时在我的Sublime编辑器上安装了Linter.它捕获的一件事说我应该总是使用!==将一个对象比较为null(我通常使用!=).

所以我改变了……但后来我注意到了!==没有用.

我有这种情况:

var x = null;
if (x !== null)
    console.log('x is not equal to null');

当我使用!==控制台打印那条线时,即使它显然不是真的.当我把它切换回来时!它表现正常.

所以我的问题是,为什么linter告诉我要使用!==如果它没有做我想要它…

我知道我错过了什么.

UPDATE
好的,所以它可能比我原先想象的要复杂一点.在我的真实代码中,我使用了!==与node.js GLOBAL对象.

console.log('Global User: ' + GLOBAL.User);

if (GLOBAL.User != null)
{
    console.log('User is not null');
}

即使GLOBAL.User为空,控制台行也会打印…

也许这个对象很特别?

更新2

好的,所以在阅读完评论并查看我的代码之后,我已经了解到!==如果对象未定义而不是null,则可能会出现问题(请参阅此文章:Why is null an object and what’s the difference between null and undefined?).

所以在我的情况下,我的全局变量可能是,取决于调用此方法的时间,未定义,空或满数据.我将返回并更新我的代码,以便它永远不会被定义,然后!==将始终如一地工作.

谢谢您的帮助!

谢谢,
大卫

解决方法:

您的global.User未定义,不为null.当使用==时,它们评估为相等,但是对于===,您要比较的项目需要是相同的类型. undefined的类型为undefined,null的类型为object.

undefined和null非常相似,但它们通常意味着两个非常不同的东西.通常undefined是某些东西没有赋值给它的结果,而null有一个值,值显式设置为“nothing”.

上一篇:javascript – 按照另一个数组的相同顺序对数组进行排序


下一篇:77_初识Java_static_学习