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; 
}
相关推荐
特立独行的猫a3 分钟前
Nuxt.js 中的路由配置详解
开发语言·前端·javascript·路由·nuxt·nuxtjs
中微子5 分钟前
小白也能懂:JavaScript 原型链和隐藏类的奇妙世界
javascript
咸虾米6 分钟前
在uniCloud云对象中定义dbJQL的便捷方法
前端·javascript
梨子同志7 分钟前
JavaScript Proxy 和 Reflect
前端·javascript
海的诗篇_9 分钟前
移除元素-JavaScript【算法学习day.04】
javascript·学习·算法
汤圆炒橘子11 分钟前
状态策略模式的优势分析
前端
__Yx__12 分钟前
JavaScript核心概念输出——原型链
javascript
勤奋的知更鸟15 分钟前
Java编程之原型模式
java·开发语言·原型模式
90后的晨仔27 分钟前
解析鸿蒙 ArkTS 中的 Union 类型与 TypeAliases类型
前端·harmonyos
珂朵莉MM28 分钟前
2021 RoboCom 世界机器人开发者大赛-高职组(初赛)解题报告 | 珂学家
java·开发语言·人工智能·算法·职场和发展·机器人