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; 
}
相关推荐
网安墨雨20 小时前
Python自动化一------pytes与allure结合生成测试报告
开发语言·自动化测试·软件测试·python·职场和发展·自动化
程序猿阿伟20 小时前
《TypeScript中Protobuf到运行时类型安全的转换指南》
javascript·安全·typescript
毕设源码李师姐20 小时前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计
忆~遂愿20 小时前
Runtime 上下文管理:计算实例的生命周期、延迟最小化与上下文切换优化
java·大数据·开发语言·人工智能·docker
沐知全栈开发20 小时前
PostgreSQL中的AND和OR操作符
开发语言
powerfulhell20 小时前
寒假python作业5
java·前端·python
1尢晞120 小时前
Java学习
java·开发语言
毕设源码-赖学姐21 小时前
【开题答辩全过程】以 基于python的电影推荐系统为例,包含答辩的问题和答案
开发语言·python
星辰_mya21 小时前
Elasticsearch线上问题之慢查询
java·开发语言·jvm
木子啊21 小时前
前端组件化:模板继承拯救发际线
前端