JavaScript中Object.prototype.toString.call()、instanceOf和Array.isArray()的区别

Object.prototype.toString.call()、instanceOf和Array.isArray()都可以用来判断一个值的类型,但是他们有一些区别。

Object.prototype.toString.call() 该方法返回一个表示对象类型的字符串。可以使用这个方法来判断一个值的类型。示例代码如下:

javascript 复制代码
// 判断变量类型
var myVar = null;
console.log(Object.prototype.toString.call(myVar)); // [object Null]
 
var myVar = {};
console.log(Object.prototype.toString.call(myVar)); // [object Object]
 
var myVar = [];
console.log(Object.prototype.toString.call(myVar)); // [object Array]

instanceof instanceof是用来检查一个对象是否是一个指定类型的实例,其返回值为一个布尔值示例代码如下:

javascript 复制代码
var myVar = new Array();
console.log(myVar instanceof Array); // true
 
var myVar = new String();
console.log(myVar instanceof String); // true
 
var myVar = new Object();
console.log(myVar instanceof Object); // true

需要注意的是,instanceof不能用来判断基本数据类型的值。

javascript 复制代码
var myVar = 'hello';
console.log(myVar instanceof String); // false

Array.isArray() 该方法用来判断一个值是否为数组类型,其返回值为一个布尔值。示例代码如下:

javascript 复制代码
var myVar = [];
console.log(Array.isArray(myVar)); // true
 
var myVar = new Array();
console.log(Array.isArray(myVar)); // true
 
var myVar = {};
console.log(Array.isArray(myVar)); // false
相关推荐
明月_清风24 分钟前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风24 分钟前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财5 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
ssshooter12 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
Live0000013 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉13 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
球球pick小樱花14 小时前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
喝水的长颈鹿14 小时前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
用户145369814587814 小时前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
codingWhat14 小时前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js