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; 
}
相关推荐
Wy. Lsy2 分钟前
Kotlin基础学习记录
开发语言·学习·kotlin
quweiie25 分钟前
tp8.0\jwt接口安全验证
前端·安全·jwt·thinkphp
Tanecious.37 分钟前
C++--红黑树
开发语言·c++
xiaoyan201541 分钟前
最新Flutter3.32+Dart3仿微信App聊天实例
前端·flutter·dart
Top`41 分钟前
Java 泛型 (Generics)
java·开发语言·windows
汪敏wangmin1 小时前
Fiddler-抓包后直接生成Loadrunner脚本或者Jmeter脚本
前端·jmeter·fiddler
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
如何使用Java WebSocket API实现客户端和服务器端的通信?
java·开发语言·websocket
Shartin1 小时前
Can201-Introduction to Networking: Application Layer应用层
服务器·开发语言·php
彤银浦2 小时前
Web学习笔记3
前端·笔记·学习·html5
江城开朗的豌豆2 小时前
退出登录后头像还在?这个缓存问题坑过多少前端!
前端·javascript·vue.js