typeof的运算

本文深入探讨了JavaScript中typeof运算符的使用及常见陷阱,包括其对不同数据类型的返回值,如undefined、boolean、string、number、object和function,特别指出null、NaN和各种对象类型(如数组、正则)的识别误区。

先上代码
typeof 1 === true ? 1 : 0
控制台打印可以看到答案是0,因为typeof先进行计算。如果改成下面这样:
typeof(1 === true ? 1 : 0)
答案则是number

typeof运算符本身只会返回字符串,

1. undefined
2. boolean
3. string
4. number
5. object
6. function

typeof来判断数据类型会有几个坑:

  1. null返回的是object,但是不能当对象使用
var obj = null;
if (typeof obj === 'object') {
    obj.a(); // 报错
}
  1. 对NaN返回的是number,但是不能进行算术运算
var obj = {};
var num = parseInt(obj.a);
if (typeof num === 'number') {
    num = num + 10; // 执行后num还是NaN
}
  1. 不能区分对象、数组、正则,对它们的操作返回都是'object'
var obj = {};
var arr = [];
var reg = /abc/g;
console.log(typeof obj);
console.log(typeof arr);
console.log(typeof reg);

转载于:https://www.cnblogs.com/douglasvegas/p/7356213.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值