JavaScript类型判断操作方法(新手必看篇)

 更新时间:2026年06月10日 09:50:55   作者:小KK_  
众所周知在JavaScript开发中,准确判断数据类型是常见需求,这篇文章主要介绍了JavaScript类型判断操作方法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

在JavaScript开发中,准确判断数据类型是日常编码的高频操作,也是不少初学者容易踩坑的地方。为什么typeof null“object”? instanceof 的原理是什么?有没有一种“万能”的类型判断方法?本文将从原始类型和引用类型出发,循序渐进的带你搞懂这类型判断背后的门道。

一. 先温习JS中的两大类型阵营

在开始讨论之前,我们先快速回顾一下JS中的数据类型划分:

原始类型

string,number,boolaen,null, undefined, bigint, Symbol

它们直接存储于栈中,赋值给变量时是值的拷贝。

引用类型

Array, function, object, Date

它们存储在堆内存中,变量保存的只是内存地址的引用。

因为这两种类型在底层存储和行为的差异,导致它们各自适合不同的判断方式。

二. typeof———简单直接,但有局限

typeof 操作符是我们最常用的类型判断工具之一。它的特点是:

  • 能准确判断除null以外的所有原始类型

  • 对于引用类型,typeof 统一返回 "object",只有一个特例:函数返回 "function"

也就是说,数组、普通对象、日期对象、正则表达式等统统被识别为 "object"

typeof []         // "object"
typeof {}         // "object"
typeof new Date() // "object"
typeof /reg/      // "object"
typeof function(){}  // "function"

让人迷惑的 null

typeof null  // "object"

为什么判断null返回的是object呢?这是因为:typeof 是通过将值转为二进制,来判断类型的,二进制前三位是 0 的统一被认为是引用类型,在计算机中,所有的引用类型被转为二进制,前三位都是 0(除了函数),而 null 转为二进制是一整串 0,所以null被错误判断为了object

三.instanceof——基于原型链的归属判断

1. 只能判断引用类型,无法判断原始类型

3. 它是通过隐式原型链来查找 x 是否隶属于 X 这个类型

[] instanceof Array        // true
{} instanceof Object       // true
new Date() instanceof Date  // true
function(){} instanceof Function  // true

四. Object.prototype.toString——终极万能判断法

如果你想要一个绝对可靠、能区分所有数据类型的方法,那非Object.prototype.toString莫属。

原理浅析

每个对象内部都有一个 [[Class]] 属性,它标记了该对象的类型标签(如 ArrayDateNumberString 等)。当我们调用 Object.prototype.toString 方法时,它会执行以下步骤:

  1. 如果值是 undefined,直接返回 "[object Undefined]"

  2. 如果值是 null,返回 "[object Null]"

  3. 否则,将值转换为一个对象(ToObject(this)),然后读取该对象的 [[Class]] 属性,最后拼接成 "[object " + [[Class]] + "]" 的形式。

由于 Object.prototype.toString 可以被任意对象调用,我们通常使用 call 或 apply 来改变它的 this 指向,使其能直接处理原始值。

Object.prototype.toString.call(123)     // "[object Number]"
Object.prototype.toString.call("hello") // "[object String]"
Object.prototype.toString.call(true)    // "[object Boolean]"
Object.prototype.toString.call(null)    // "[object Null]"
Object.prototype.toString.call(undefined) // "[object Undefined]"
Object.prototype.toString.call([])       // "[object Array]"
Object.prototype.toString.call({})       // "[object Object]"
Object.prototype.toString.call(new Date()) // "[object Date]"
Object.prototype.toString.call(/reg/)    // "[object RegExp]"
Object.prototype.toString.call(function(){}) // "[object Function]"

五. Array.isArray——专为数组而生

检测数组是最常见的需求之一,虽然Object.prototype.toString.call(arr) === “[object Array]"万无一失,但是数组有一个专门的Array.isArray()方法,更加简单直接。

Array.isArray([])      // true
Array.isArray({})      // false
Array.isArray(new Array(5))  // true

六.各方法对比总结

方法适用场景不足之处
typeof判断原始类型(除null外)和函数typeof null → "object";无法区分具体的对象类型(数组、日期等)
instanceof判断某个对象是否由指定构造函数创建无法判断原始类型
Object.prototype.toString全场景通用,精准返回每个数据的内置类型写法稍长,通常需要封装
Array.isArray专用于判断数组只解决数组场景

到此这篇关于JavaScript类型判断操作方法的文章就介绍到这了,更多相关JS类型判断内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • js方块躲避游戏代码

    js方块躲避游戏代码

    鼠标控制,空色方块不要让蓝色方块碰到就可以,看能玩多久,是个javascript不错的一个游戏啊,想用js写游戏的朋友可以参考下,看代码应该是国外的人写的
    2008-05-05
  • js动态实现表格添加和删除操作

    js动态实现表格添加和删除操作

    这篇文章主要为大家详细介绍了js动态实现表格添加和删除操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • document.documentElement的一些使用技巧

    document.documentElement的一些使用技巧

    documentElement 属性可返回文档的根节点,接下来为大家详细介绍下document.documentElement的一些使用技巧,感兴趣的朋友可以参考下哈
    2013-04-04
  • js展开闭合效果演示代码

    js展开闭合效果演示代码

    本文为大家介绍下js如何实现展开闭合效果,具体代码如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • JS加jquery简单实现标签元素的显示或隐藏

    JS加jquery简单实现标签元素的显示或隐藏

    标签元素的显示或隐藏在使用中还是挺频繁的,下面有个不错的示例,大家可以参考下,或许有所帮助
    2013-09-09
  • JS获取父节点方法

    JS获取父节点方法

    在Web应用程序特别是Web2.0程序开发中,经常要获取页面中某个元素,然后更新该元素的样式、内容等。
    2009-08-08
  • JavaScript错误处理和堆栈追踪详解

    JavaScript错误处理和堆栈追踪详解

    这篇文章主要为大家详细介绍了JavaScript错误处理和堆栈追踪的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • JavaScript检查弹出窗口是否被阻拦的方法技巧

    JavaScript检查弹出窗口是否被阻拦的方法技巧

    这篇文章主要介绍了JavaScript检查弹出窗口是否被阻拦的方法技巧,本文用于检测window.open弹出的窗口是否被阻拦,需要的朋友可以参考下
    2015-03-03
  • js 可选链操作符的使用

    js 可选链操作符的使用

    可选链操作符(?.)允许读取位于链接对象链身处的属性的值,本文就详细的介绍一下,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • 微信小程序scroll-x失效的完美解决方法

    微信小程序scroll-x失效的完美解决方法

    在微信小程序的文档中,使用scroll-view标签,然后给它设置一个scroll-x就可以实现元素,横向排列,可以左右滑动,但是在实际开发中会遇到各种问题,下面小编给大家带来了微信小程序scroll-x失效的完美解决方法,需要的朋友可以参考下
    2018-07-07

最新评论