js 类型与类型判断

本文介绍了JavaScript中的数据类型,包括基本类型和引用类型,并详细讨论了typeof操作符、instanceOf方法以及通过Object.prototype.toString.call(value)进行类型判断的方法。文章还提供了一个通用的getType方法示例,用于更准确地检测变量的类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

日常积累,欢迎指正

js 数据类型

  • 基本数据类型:undefined、null、Boolean、number、string,symbol
  • 引用数据类型 :object (function)

typeof

只能判断值类型、对象和函数
typeof 的返回值有 :

  • undefined、boolean、number、 string,symbol
  • object (null array object)
  • function

instance

a instanceOf A

本质是沿着 a 的原型链上是否有 A ,如果有就返回 true 否则返回 false

const arr=new Array()
arr instanceOf Array // true
arr instanceOf Object // true

constructor

原理类似于 instanceOf

value.constructor === Boolean/Number/ String/ Array/ Object/Function/Symbol

Object.prototype.toString.call(value)

可以判断任意数据类型
这里封装通用方法 getType

  getType=(value)=>{
    return Object.prototype.toString.call(value).match(/\b\s\w+\b/g)[0].trim().toLowerCase();
  }

方法详解 - 以 undefined 类型判断为例

  • Object.prototype.toString.call(undefined) 返回 “[object Undefined]”
  • “[object Undefined]”.match(/\b\s\w+\b/g)[0] // 匹配获取到 ’ Object’
  • .trim() // 去掉空格得到 ‘Object’
  • .toLowerCase() // 大小写转换得到 ‘object’ 或
  • .toUpperCase() // 大小写转换得到 ‘OBJECT’
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值