js检测数据类型有那些方法

简介: js检测数据类型有那些方法
  1. typeof

直接在计算机底层基于数据类型的值(二进制)进行检测
tyepof null "object" 对象存储在计算机中,都是以000开始的二进制存储,null也是,所以检测出来的结果是对象
typeof 普通对象/数组对象/正则对象/日期对象 "object"

  1. instanceof 检测当前实例是否属于这个类的

底层机制:只要当前类出现在实例的原型链上,结果都是true
由于我们可以肆意的修改原型的指向,所以检测出来的结果是不准的
不能检测基本数据类型

  1. constructor

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

  1. Object.prototype.toString.call(value)

标准检测数据类型的办法:Object.prototype.toString不是转换为字符串,是返回当前实例所属类的信息
标准检测的办法 "[object Number/String/Boolean/Null/Undefined/Symbol/Object/Array/RegExp/Date/Function]"
下面封闭一个判断数据类型方法:

function detectionType(data) {
   
    const class2type = {
   
        '[object Null]': "null",
        '[object Date]': "date",
        '[object Error]': "error",
        '[object Array]': "array",
        '[object Number]': "number",
        '[object Object]': "object",
        '[object RegExp]': "regexp",
        '[object String]': "string",
        '[object Symbol]': "symbol",
        '[object Boolean]': "boolean",
        '[object Function]': "function",
        '[object Undefined]': "undefined",
    };
    // 基本数据类型都采用typeof检测
    if (typeof data === "object" || typeof data === "function") {
   
        return class2type[Object.prototype.toString.call(data)] || "object";
    } else {
   
        return typeof data;
    }
}
相关文章
|
26天前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
24天前
|
监控 JavaScript Java
Node.js中内存泄漏的检测方法
检测内存泄漏需要综合运用多种方法,并结合实际的应用场景和代码特点进行分析。及时发现和解决内存泄漏问题,可以提高应用的稳定性和性能,避免潜在的风险和故障。同时,不断学习和掌握内存管理的知识,也是有效预防内存泄漏的重要途径。
118 52
|
1月前
|
缓存 JavaScript UED
js中BOM中的方法
【10月更文挑战第31天】
|
2天前
|
存储 JavaScript 前端开发
JavaScript中的数据类型以及存储上的差别
通过本文的介绍,希望您能够深入理解JavaScript中的数据类型及其存储差别,并在实际编程中灵活运用这些知识,以提高代码的性能和稳定性。
14 3
|
25天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
38 5
|
26天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
25 1
|
26天前
|
存储 JavaScript 前端开发
js中的数据类型
JavaScript 中的数据类型包括五种基本类型(String、Number、Undefined、Boolean、Null)和三种引用类型(Object、Array、Function,以及ES6新增的Symbol)。基本类型直接存储值,引用类型存储的是指向实际数据的内存地址。了解它们的区别对于掌握 JavaScript 的变量赋值和函数传参至关重要。
21 1
|
1月前
|
JavaScript 前端开发
.js方法参数argument
【10月更文挑战第26天】`arguments` 对象为JavaScript函数提供了一种灵活处理参数的方式,能够满足各种不同的参数传递和处理需求,在实际开发中具有广泛的应用价值。
38 7
|
7月前
|
JavaScript 前端开发
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
JavaScript DOM 操作:如何检测浏览器是否支持某个特性?
53 0
|
Web App开发 编解码 JavaScript
js检测浏览器及系统信息
js检测浏览器及系统信息
283 0