js基础-数据类型检测

1、typeof关键字

  1. 返回一个字符串,作用于基本数据类型
  2. 直接在计算机底层基于数据类型的值(二进制) 进行检测。
  3. typeof null "object" 对象存储在计算机中,都是以000 开始的二进制存储,null也是,所以检测出来的结果是对象。
  4. typeof 普通对象/数组对象/正则对象/日期对象 "object"

2、instanceof 关键字

  1. 返回一个布尔值 ,左边是 检测对象 右边是判断的类型 class
  2. 底层机制:只要当前类出现在实例的原型上,结果都是 true
  3. 由于我们可以肆意的修改原型的指向,所以检测的结果不准的
  4. 不能检测基本数据类型

arr instanceof Array ==>true

arr instanceof RegExp == >false

arr instanceof Object ==> true

1 instanceof Number ==> false

javascript 复制代码
// 实例.__proto__ === 类.prototype
function instance_of(ex,cl) {
    let classFunP = cl.prototype,
        proto = ex.getPrototypeOf(ex);
    while(true) {
        if(proto === null) {
            return false;
        }
        if( proto === classFunP ) {
            return true;
        }
         proto = Object.getPrototypeOf(proto);
     }


}

3、constructor属性

  1. 用起来看似比instanceof 还好用一些(基本类型支持的)
  2. constructor可以随便改,所以也不准。

arr.constructor == Array // true

arr.constructor == RegExp // false

arr.constructor == Object // false

1.constructor == Number // true

4、Object.prototype.toString().call(value)

  1. 标准检测数据类型的方法:Object.prototype.toString 不是转换为字符串,是返回当前实例所属类的信息。
  2. 标准的检测的方法 "object Number/String/Boolean/Null/Undefined/Symbol/Onject/Array/Regexp/Date"

最后总结的封装的方法

javascript 复制代码
const defaultTypeMap = {
  "object Number": "number",
  "object String": "string",
  "object Boolean":"boolean",
  "object Array": "array",
  "object Object": "object",
  "object Date": "date",
  "object Function": "function",
  "object Error": "error",
  "object RegExp": "regExp",
  "object Symbol": "symbol",
}

function typeCheck(value) {
    // 如果是null 或者 undefined 直接返回
  if(value == null) {
    return value + "";
  }
  const toString = Object.prototype.toString;

  return typeof value == "object" || typeof value == "function" ? defaultTypeMap[toString.call(value)]   || "object": typeof value; 
}
相关推荐
在水一缸2 分钟前
重塑前端开发认知:当 AI 遇见 HTML 的“不合理有效性”
前端·人工智能·html·ai编程·claude·前端开发
SwJieJie7 分钟前
Webpack vs Vite 构建工程化实战(Vue 项目深度解析)
前端·vue.js·webpack·node.js
lihao lihao9 分钟前
linux线程
java·开发语言·jvm
swg32132115 分钟前
Redis实现主从选举
java·前端·redis
码云骑士16 分钟前
03-Python可变对象与不可变对象(下)-深浅拷贝的底层真相
开发语言·python
sycmancia18 分钟前
Qt——自定义模型类
开发语言·qt
英俊潇洒美少年18 分钟前
前端核心性能指标全解(CWV三大指标+辅助指标、检测方式、优化、面试背诵)
前端
alexander06819 分钟前
JavaScript 中,对象内部函数的几种等价写法,对象外部的 几种等价写法
javascript
云水一下20 分钟前
Vue.js从零到精通系列(八):项目实战——构建一个完整的电商后台管理系统
前端·javascript·vue.js