当前位置: 首页 > news >正文

javascript检测数据类型的方法

1. typeof 运算符

typeof是一个用来检测变量的基本数据类型的运算符。它可以返回以下几种类型的字符串:“undefined”、“boolean”、“number”、“string”、“object”、“function” 和 “symbol”(ES6+)。需要注意的是,对于 null 和 array,typeof 都返回 “object”,这可能导致一些混淆。

javascript
console.log(typeof 42);             // "number"
console.log(typeof 'Hello');        // "string"
console.log(typeof true);           // "boolean"
console.log(typeof {});             // "object"
console.log(typeof []);             // "object"
console.log(typeof null);           // "object"
console.log(typeof function() {});  // "function"
  1. 优点:
  • 直接且易于理解,用于基础数据类型的检测非常有效。
  1. 缺点:

对于复杂类型(如数组、null、正则表达式),返回的结果不够准确。例如,数组和普通对象都返回 “object”,null 也返回 “object”,这可能会导致误解。

2. instanceof 运算符

instanceof 用于检测一个对象是否是另一个对象的实例。它可以用于检查对象的构造函数。

console.log([] instanceof Array);        // true
console.log({} instanceof Object);       // true
console.log(new Date() instanceof Date); // true
console.log(/regex/ instanceof RegExp);  // true
console.log([] instanceof Object);       // true (数组也是对象)
  1. 优点:
  • 能够检查对象的构造函数,区分不同的对象类型(例如区分数组和普通对象)。
  1. 缺点:

对于跨窗口或跨框架的对象,instanceof 可能无法正确识别,因为它依赖于构造函数的 prototype。例如,在不同的浏览器窗口中创建的对象可能无法识别。

  1. 改进:

可以用 Object.prototype.toString.call() 来补充这种情况下的类型检测。

3. Array.isArray()

Array.isArray() 方法用于检测一个对象是否是数组。这是 typeof 和 instanceof 无法直接检测数组的情况。

console.log(Array.isArray([]));          // true
console.log(Array.isArray({}));          // false
console.log(Array.isArray('string'));    // false
console.log(Array.isArray(new Array())); // true
  1. 优点:
  • 专门用于检测数组,避免了 typeof 对数组的模糊处理。
  1. 缺点:
  • 仅限于数组检测,对于其他数据类型不适用。

改进:

适用于需要明确检测数组的场景,如数组操作前的验证。

4. Object.prototype.toString.call()

Object.prototype.toString.call() 方法提供了最准确的方式来检测对象的原始类型,包括Array、Date、RegExp 等。

console.log(Object.prototype.toString.call([]));           // "[object Array]"
console.log(Object.prototype.toString.call({}));           // "[object Object]"
console.log(Object.prototype.toString.call(new Date()));    // "[object Date]"
console.log(Object.prototype.toString.call(/regex/));       // "[object RegExp]"
console.log(Object.prototype.toString.call(null));          // "[object Null]"
console.log(Object.prototype.toString.call(undefined));     // "[object Undefined]"
  1. 优点:
  • 提供最准确的类型检测,能够区分大多数数据类型,包括 null 和 undefined。
  1. 缺点:
  • 语法相对复杂,需要调用 Object.prototype.toString.call()。

5. Number.isNaN() 和 isNaN()

Number.isNaN() 方法用于检测一个值是否是 NaN 且其类型为 Number。
isNaN()方法则会先尝试将值转换为数字,然后再判断是否为 NaN。

console.log(Number.isNaN(NaN));         // true
console.log(Number.isNaN('string'));    // false
console.log(isNaN(NaN));                // true
console.log(isNaN('string'));           // true (因为 'string' 被转换成 NaN)
console.log(isNaN(42));                 // false
  1. 优点:
  • Number.isNaN() 准确检测 NaN,避免了 isNaN() 的类型转换问题。
  1. 缺点:
  • isNaN() 会将非数字值转换为 NaN,可能导致误判。

改进:

在需要检查 NaN 时使用 Number.isNaN(),避免 isNaN() 的类型转换问题。

6. constructor 属性

constructor 属性可以用来检测一个对象的构造函数,但这种方法不如 instanceof 可靠,因为它可能会被改变。

console.log(([]).constructor === Array);   // true
console.log(({}).constructor === Object);  // true
console.log((new Date()).constructor === Date); // true
console.log((/regex/).constructor === RegExp); // true
console.log((42).constructor === Number); // true
  1. 优点:
  • 直接检测构造函数,语法简单明了。
  1. 缺点:
  • constructor 属性可能被篡改,因此不总是可靠。例如,如果对象的 constructor 被修改,检测结果可能不准确。

7 总结

  • typeof 适用于基本数据类型的检查,但对于 null 和数组不够精确。
  • instanceof 适用于检查对象是否为特定构造函数的实例。
  • Array.isArray() 专门用于检测数组。
  • Object.prototype.toString.call() 提供了最准确的类型检测方式。
  • Number.isNaN() 用于检测 NaN,避免 isNaN() 的一些陷阱。
http://www.lryc.cn/news/442521.html

相关文章:

  • 生信初学者教程(五):R语言基础
  • 深度学习计算
  • Hexo博客私有部署Twikoo评论系统并迁移评论记录(自定义邮件回复模板)
  • Vue.js 与 Flask/Django 后端配合:构建现代 Web 应用的最佳实践
  • 【笔记】自动驾驶预测与决策规划_Part3_路径与轨迹规划
  • Shiro-721—漏洞分析(CVE-2019-12422)
  • 【Python语言初识(一)】
  • Python 中的方法解析顺序(MRO)
  • MySQL表的内外连接
  • 系统架构设计师:软件架构的演化和维护
  • QT的dropEvent函数进入不了
  • Spring Boot 入门
  • LDD学习2--Scull(TODO)
  • 【算法-堆排序】
  • 音视频入门基础:AAC专题(4)——ADTS格式的AAC裸流实例分析
  • 【第33章】Spring Cloud之SkyWalking服务链路追踪
  • 如何选择OS--Linux不同Distribution的选用
  • cesium效果不酷炫怎么办--增加渲染器
  • 计算机网络:概述 --- 体系结构
  • DEPLOT: One-shot visual language reasoning by plot-to-table translation论文阅读
  • 从 HDFS 迁移到 MinIO 企业对象存储
  • Rust 常见问题汇总
  • java泛型类与泛型方法
  • Android String资源文件中,空格、换行以及特殊字符如何表示
  • CUDA及GPU学习资源汇总
  • uniapp vue3 梯形选项卡组件
  • 如何在微信小程序中实现WebSocket连接
  • 二级等保测评中安全物理环境的重要性及高危项分析
  • C++11——lambda
  • Dubbo3序列化安全问题