(JS)数据类型大揭秘:深度解析几种最常用的方法

前言:

不论你已经学习过几种数据类型的判断方法,本文将带给大家今后最最最实用的三种方法。 并且通过一些实例,详细分析它的使用方法和范围,及其优缺点

本文讨论的数据类型

七种原始数据类型(附带两种es6新增):

  1. string
  2. number
  3. boolean
  4. undefined
  5. null
  6. symbol
  7. big number

以及五种引用类型:

  1. 对象
  2. 数组
  3. 方法
  4. 日期
  5. 正则表达式

1.typeof

typeof 是一个用于检测给定变量的数据类型的运算符。它能返回一个表示变量类型的字符串。

使用方法typeof(xxx) 、 typeof xxx :即加括号或空格均可。

使用范围: 可以准确判断 除null之外 的原始数据类型(六种),还可以判断function。

javascript 复制代码
//原理:typeof 将数据转化为2进制数,前面三位是0就是对象
//除null之外 的原始数据类型
console.log(typeof 1);   //number
console.log(typeof 'Bill'); //string
console.log(typeof 123n);  //bigint
console.log(typeof true);  //boolean
console.log(typeof null); //object 历史遗留问题

//2. typeof不能判断引用类型,但是 function 除外
console.log(typeof {}); //object
console.log(typeof []); //object
console.log(typeof function(){}); //function

优点

  1. 简单易用: typeof 是一种简单的方式来获取变量的基本数据类型,特别是在处理基本数据类型时,代码变得简洁而易读。
  2. 适用于原始数据类型
  3. 无需变量声明: typeof 可以在变量未声明的情况下使用,不会抛出错误。这在某些动态环境中可能是一个优点。

缺点:

  1. 不适用于详细类型检查: typeof 并不是一种详细的类型检查工具,特别是对于复杂数据类型(如对象、数组),它只能告诉你它们是对象,而无法区分具体的对象类型。
  2. null 的问题: typeof null 返回 "object",这是 JavaScript 设计的历史遗留问题,可能导致误解。
  3. 无法检测自定义对象类型: 对于自定义的对象类型,typeof 只能返回 "object",而不能区分不同的对象类型。
  4. 不能检测函数参数类型: 在函数参数类型检查的场景中,typeof 通常不够用,因为它不能区分不同的对象类型。

2.instanceof

instanceof 是通过原型链查找来判断数据类型的一个操作符,其结果是返回一个布尔值。

使用方法: object instanceof constructor

其中object是要检查的对象,constructor是要检查的构造函数。instanceof的工作原理是检查object的原型链上是否存在constructor.prototype,有则返回true。

使用范围: 用于判断引用类型。

javascript 复制代码
console.log(instanceOF([],Array)); //true
console.log(instanceOF([],Object)); //true

console.log(instanceOF(obj,Object)); //true
console.log(instanceOF(function(){},Function)); //true
console.log(instanceOF(time,Date)); //true

console.log(str instanceof String);//false

优点:

  1. 简单易用: instanceof 是一种比较简单的类型检测方法,适用于引用类型的判断。
  2. 原型链检测: 通过检查原型链,instanceof 可以检测对象的继承关系,而不仅仅是直接实例关系。

缺点:

  1. 无法跨 iframe 检测: 如果对象是在不同的 iframe 中创建的,instanceof 将返回 false,因为它只在同一全局对象中有效。
  2. 无法准确检测基本类型: instanceof 主要用于检测对象的实例关系,对于基本数据类型(如字符串、数字、布尔值等),它的判断可能会出现错误。

------那么如何解决这些问题呢?

实际开发中,为了更精确地进行类型检查,就会引入下面这种方法

3.object.prototype.toString

Object.prototype.toString 方法是一种用于获取对象的内部属性 [[Class]] 的通用方法。该属性表示对象的内部标识,可以用于进行更准确的类型判断。

使用方法: Object.prototype.toString 方法不是直接调用 的,而是通过以下方式调用:Object.prototype.toString.call。返回由 "object" 和 class 和 "" 三部分组成的字符串,而class表示对象的类型。

使用范围: 适用于一切数据类型

javascript 复制代码
console.log(Object.prototype.toString.call('hello' ));//[object String]
console.log(Object.prototype.toString.call(123)); //[object Number]
console.log(Object.prototype.toString.call(false)); // [object Boolean]
console.log(Object.prototype.toString.call(undefined));//[object Undefined]
console.log(Object.prototype.toString.call(null)); //[object Null]
console.log(Object.prototype.toString.call(123n)); //[object BigInt]
console.log(Object.prototype.toString.call(Symbol('hello'))); //[object Symbol]
console.log(Object.prototype.toString.call({})); //[object Object]
console.log(Object.prototype.toString.call([])); //[object Array]
console.log(Object.prototype.toString.call(function(){})); //[object Function]
let data = new Date //日期
console.log(Object.prototype.toString.call(data)); //[object Date]

优点: 通过调用 Object.prototype.toString.call,我们可以获取到更准确的类型信息,尤其是对于内置对象和用户自定义对象,对原始数据类型也同样适用。

总结

这篇文章中,我们详细介绍了 JavaScript 中的三种最常用的类型判断方法:typeof 方法、instanceof 方法、Object.prototype.toString.call 方法。

总的来说,本文介绍了这些类型判断方法的用法和优缺点,并强调了在不同情况下选择合适的方法以确保准确性和可靠性。在你的实际项目中,你更倾向于使用哪种类型判断方法呢?你遇到过哪些关于类型判断的挑战?欢迎分享你的经验和看法!

点个免费的赞鼓励支持一下吧! 个人Gitee仓库:Code Space: 记录学习code中的点点滴滴 (gitee.com)

相关推荐
海兰7 小时前
【web应用】Excel 项目数据自动化分析系统(AI 驱动分析)详细设计与部署指南(附源代码)
前端·人工智能·自动化·excel
小二·7 小时前
Next.js 15 全栈开发实战
开发语言·javascript·ecmascript
2501_940041747 小时前
技术分享:高质量全栈开发提示词设计实践 —— 覆盖简单到复杂
前端·prompt
IT_陈寒7 小时前
Python的os.path.join居然能这么坑?
前端·人工智能·后端
艳阳天_.7 小时前
星瀚弹框页面实现
java·前端·python
EdgeOne边缘安全加速平台7 小时前
EdgeOne Web 防护×AI 升级:让 AI 既参与攻击识别,也参与误报纠错
前端·人工智能·腾讯云·edgeone
nuIl7 小时前
实现一个 Coding Agent(6):并行工具调用
前端·ai编程·cursor
Rain5098 小时前
2.1 Nest.js 项目初始化与模块化架构
开发语言·前端·javascript·后端·架构·数据分析·node.js
cjp5608 小时前
009. ASP.NET WEB API 用户关联esp32设备
前端·后端·asp.net
Insseals8 小时前
因斯特浮动模块快速接头✨五大核心优势
前端