typeof
运算符 将给定变量的类型作为字符串返回。
typeof 42; // number
typeof test; // string
typeof true; // boolean
typeof (void 0); // undefined
typeof BigInt(1234); // bigint
typeof Symbol(foo); // symbol
typeof ({ answer: 42 }); // object
typeof function() {}; // function
// As far as `typeof` is concerned, all objects are the same.
class MyClass {}
typeof (new MyClass()); // object
这是一般的想法: typeof
运算符返回 8 种 JavaScript 数据类型中 给定值是 此规则有一个关键例外: null
。
null
一个大问题 typeof
就是它 typeof null === object
,这种行为是有历史原因的 ,改变这种行为的提议被拒绝了,所以看起来 JavaScript 被这个怪癖卡住了。
检查一个值是否实际上是一个对象的解决方法 typeof
是检查类型是否为 object
并且该值不 严格 等于 null
。
function isObject(v) {
return typeof v === object && v !== null;
}
错误案例
typeof
使用它,运算符可能会引发错误 块作用域变量 之前
// Throws ReferenceError: v is not defined
console.log(typeof v);
let v;
此行为 仅 适用于块范围的变量。 例如如果您不定义 v
总之,上面的脚本可以正常工作。
console.log(typeof v); // undefined
//let v;
块范围的变量是唯一的情况 typeof
引发错误。 否则 typeof
总会成功的。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
请登录后查看评论内容