JavaScript判断变量是否为undefined的两种写法区别

网络编程 发布日期:2024/10/10 浏览次数:1

正在浏览:JavaScript判断变量是否为undefined的两种写法区别

工作中我们经常需要判断某个变量/属性是否为undefined。通常有两种写法
复制代码 代码如下:
// 方式1
typeof age === 'undefined';

// 方式2
age === undefined

这两种写法有什么区别吗? 应该使用哪一种呢?看看下面的例子
复制代码 代码如下:
typeof age === 'undefined'; // true

标识符 age 没有声明过,输出true。

再看另一个例子
复制代码 代码如下:
age === undefined; // 报错

Firebug提示age is not defined,

JavaScript判断变量是否为undefined的两种写法区别

这就是两者的区别, 即不确定age是否声明或定义时用方式1,确定的则可以用方式2。使用方式1如果变量没有声明,代码也不会报错,但方式2会报错。看似方式1容错性更好,实际会是潜伏了的Bug。变量先声明再使用永远是个好习惯。

此外,方式1是两次运算,方式2是一次。

高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。