JavaScript 判断数据类型有哪些方法?

有四种方法:

方法一:typeof

typeof 运算符返回一个字符串,表示操作数的类型。下图是使用 typeof 判断类型的汇总:

可以看到,typeof 判断类型有两个缺点:

对 null 值的判断是 object,这个是历史遗留问题

对 object 的判断区分不出具体的对象类型
方法二: instanceof

instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

// 定义构造函数

function C(){}

function D(){}

var o = new C();

o instanceof C; // true,因为 Object.getPrototypeOf(o) === C.prototype

方法三:Object.prototype.constructor

constructor 属性返回 Object 的构造函数(用于创建实例对象)。

注意:此属性的值是对函数本身的引用,而不是一个包含函数名称的字符串。

所有对象(使用 Object.create(null) 创建的对象除外)都将具有 constructor 属性。在没有显式使用构造函数的情况下,创建的对象(例如对象和数组文本)将具有 constructor 属性,这个属性指向该对象的基本对象构造函数类型。

const o = {}

o.constructor === Object // true

const o = new Object

o.constructor === Object // true

方法四:Object.prototype.toString

Object.prototype.toString 方法返回一个表示该对象的字符串。

const toString = Object.prototype.toString;

toString.call(new Date()); // [object Date]

toString.call(new String()); // [object String]

小练习:如何实现 instanceof?

答案:

function myInstanceof(left, right) {

let proto = Object.getPrototypeOf(left); // 获取对象的原型

let prototype = right.prototype; // 获取构造函数的 prototype 对象

// 判断构造函数的 prototype 对象是否在对象的原型链上

while (true) {

if (!proto) return false;

if (proto === prototype) return true;

proto = Object.getPrototypeOf(proto);

}

}

作者:LeetCode

链接:https://leetcode.cn/leetbook/read/javascript-interview-2/7mduie/

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关推荐
Dxy12393102162 分钟前
python使用requests发送请求ssl错误
开发语言·python·ssl
小林熬夜学编程7 分钟前
【Linux系统编程】第四十二弹---多线程编程全攻略:涵盖线程创建、异常处理、用途、进程对比及线程控制
linux·服务器·c语言·开发语言·c++
昂子的博客13 分钟前
通过mybatis和mybatis plus 实现用户注册功能和基础的增删改查
java·开发语言·mybatis
£suPerpanda16 分钟前
牛客周赛 Round65 补题DEF
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
KeithTsui23 分钟前
ZFC in LEAN 之 前集的等价关系(Equivalence on Pre-set)详解
开发语言·其他·算法·binder·swift
code .24 分钟前
C++各个版本的主要特性
开发语言·c++·现代c++
小远yyds35 分钟前
跨平台使用高德地图服务
前端·javascript·vue.js·小程序·uni-app
暴怒香菜统治世界39 分钟前
数据结构--二叉树_链式(下)
c语言·开发语言·数据结构·算法·链表
SONGW20181 小时前
其他节点使用kubectl访问集群,kubeconfig配置文件 详解
java·开发语言
weixin_516875651 小时前
使用 axios 拦截器实现请求和响应的统一处理(附常见面试题)
前端·javascript·vue.js