在PHP中,你可以这样做if(isset($array['foo'])){…}。在JavaScript中,你经常使用if(array.foo){…}来做同样的事情,但这不是完全相同的语句。条件也将计算为false if数组。Foo确实存在,但为false或0(也可能为其他值)。
JavaScript中与PHP的isset完美对应的是什么?
从更广泛的意义上说,一个关于JavaScript如何处理不存在的变量、没有值的变量等的通用的、完整的指南会很方便。
更新:11年零11个月前,我发布了这个问题,哇,它仍然有很多活动。现在,我非常确定,当我写这篇文章时,我只是想知道如何检查关联数组(也就是字典)中属性的存在,因此(对我来说)正确的答案涉及hasOwnProperty或in操作符。我对检查局部或全局变量不感兴趣。
但是,虽然我记得很清楚,但在写的问题中,这种意图并不十分清楚,甚至与之直接矛盾!我还没提到关联数组,PHP的isset也有其他功能。让这成为我们所有人的一个教训,让我们知道在一个问题中正确地陈述你的要求是多么重要,以及全局变量、局部变量、对象属性、字典键和其他什么东西是多么重要。
与此同时,很多很多人也提供了这个问题的答案,所以对于那些通过谷歌找到这个问题的人来说,我很高兴我的含糊在某种程度上有所帮助。不管怎样,我只是想澄清一下。
这是一个非常可靠的测试变量是否存在的解决方案:
var setOrNot = typeof variable !== typeof undefined ? true : false;
不幸的是,您不能简单地将其封装在函数中。
你可能会这样想:
function isset(variable) {
return typeof variable !== typeof undefined ? true : false;
}
然而,如果变量variable没有定义,这将产生一个引用错误,因为你不能将一个不存在的变量传递给函数:
未定义foo
另一方面,它允许你测试函数参数是否未定义:
var a = '5';
var test = function(x, y) {
console.log(isset(x));
console.log(isset(y));
};
test(a);
// OUTPUT :
// ------------
// TRUE
// FALSE
即使y的值没有传递给函数测试,我们的isset函数在这个上下文中工作得很好,因为y在函数测试中是一个未定义的值。
在ES6中要小心,如果你想检查let变量的声明并声明它,那么之前的所有解决方案都是无效的
例子
let myTest = 'text';
if(typeof myTest === "undefined") {
var myTest = 'new text'; // can't be a let because let declare in a scope
}
您将看到一个错误
标识符'myTest'已经声明
解决办法是用一个变量
var myTest = 'text'; // I replace let by a var
if(typeof myTest === "undefined") {
var myTest = 'new text';
}
另一个解决方案是,如果你可以通过一个变量来改变一个let,你需要删除你的变量
let myTest = 'text';
if(typeof myTest === "undefined") {
myTest = 'new text'; // I remove the var declaration
}