js中如何对数据类型进行区分判断?有几种方法?

1.typeof

返回值 :返回值包括 "undefined", "boolean", "number", "string", "bigint", "symbol", "object" 和 "function"。

需要注意的就是typeof无法区分引用数据类型(对象和数组 ),且对 null的判断为object

javascript 复制代码
typeof 42; // "number"
typeof "Hello"; // "string"
typeof true; // "boolean"
typeof undefined; // "undefined"
typeof Symbol("id"); // "symbol"
typeof function() {}; // "function"
typeof NaN; // "number"
typeof null; // "object" (这是 JavaScript 的一个历史遗留问题)
typeof {}; // "object"
typeof []; // "object"

2.instanceof 操作符
返回值 :返回布尔值 truefalse

需要注意的是instanceof 适用于引用数据类型,如对象、数组、函数等。对于基本数据类型(如NumberStringBoolean等),instanceof 并不能正确区分。

javascript 复制代码
let arr = [];
arr instanceof Array; // true
let obj = {};
obj instanceof Object; // true
function Person(name) {
    this.name = name;
}
let person = new Person("John");
person instanceof Person; // true

// 对于基本数据类型,instanceof 的行为不如预期:
let num = 42;
console.log(num instanceof Number); // false
let str = "Hello";
console.log(str instanceof String); // false
let bool = true;
console.log(bool instanceof Boolean); // false

3.Object.prototype.toString.call() 方法

用法 :使用 Object.prototype.toString.call() 方法可以获取对象的内部属性 [[Class]] 的值,从而准确判断其类型。
返回值 :返回一个以 [object 开头、] 结尾的字符串。

javascript 复制代码
Object.prototype.toString.call(42); // "[object Number]"
Object.prototype.toString.call("Hello"); // "[object String]"
Object.prototype.toString.call(true); // "[object Boolean]"
Object.prototype.toString.call(undefined); // "[object Undefined]"
Object.prototype.toString.call(null); // "[object Null]"
Object.prototype.toString.call({}); // "[object Object]"
Object.prototype.toString.call([]); // "[object Array]"
Object.prototype.toString.call(function() {}); // "[object Function]"
Object.prototype.toString.call(Symbol("id")); // "[object Symbol]"

小结

  • 基本数据类型 :使用typeofObject.prototype.toString.call()来区分。
  • 引用数据类型 :使用instanceofObject.prototype.toString.call()来区分。

小补充:

constructor

javascript 复制代码
(2).constructor === Number// true
([]).constructor === Array // true
隐患:
constructor代表的是构造函数指向的类型,可以被修改的js
function Fn(){}
Fn.prototype = new Array();
var f = new Fn();
// 在这种情况下,f的constructor属性不再指向Fn,而是指向 Array,因为 Fn.prototype 被设置为一个 Array 实例
// 在使用 JavaScript 中的原型继承时,要特别注意 constructor 属性可能带来的不准确性,并在必要时手动重置它以确保类型检测的可靠性。对于类型检测,Object.prototype.toString.call() 方法更为可靠,因为它不受 constructor 属性修改的影响。
相关推荐
苏琢玉几秒前
从 Hexo 到 Astro:重构我的个人博客
前端·hexo
Glommer4 分钟前
某音 Js 逆向思路
javascript·逆向
weixin_307779137 分钟前
在Linux服务器上使用Jenkins和Poetry实现Python项目自动化
linux·开发语言·python·自动化·jenkins
润 下7 分钟前
C语言——深入解析C语言指针:从基础到实践从入门到精通(四)
c语言·开发语言·人工智能·经验分享·笔记·程序人生·其他
街尾杂货店&7 分钟前
webpack - 单独打包指定JS文件(因为不确定打出的前端包所访问的后端IP,需要对项目中IP配置文件单独拿出来,方便运维部署的时候对IP做修改)
前端·javascript·webpack
月光技术杂谈9 分钟前
用Deepseek 实现一个基于web的扣图应用
前端·javascript·html5·ccs·tensorflow.js·canvas api
Empty_77711 分钟前
Python编程之常用模块
开发语言·网络·python
小火柴12315 分钟前
利用R绘制箱线图
开发语言·r语言
wheeldown25 分钟前
【Linux】Linux 进程通信:System V 共享内存(最快方案)C++ 封装实战 + 通信案例,4 类经典 Bug 快速修复
linux·运维·服务器·开发语言
小年糕是糕手35 分钟前
【数据结构】双向链表“0”基础知识讲解 + 实战演练
c语言·开发语言·数据结构·c++·学习·算法·链表