js 类型与类型判断

前言

日常积累,欢迎指正

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’

你可能感兴趣的:(前端,JS)