JS | JS中判断数组的6种方法,你知道几个?

news2024/11/24 3:00:43

目录

1、通过 instanceof 运算符判断

2、通过 constructor 构造函数属性判断

3、通过 Object.prototype.toString.call() 方法判断

4、通过 Array.isArray() 判断

5、通过Array原型链上的 isPrototypeOf() 方法判断

6、通过 Object.getPrototypeOf() 方法判断


因为数组是属于object类型的,也就是引用类型,所以不能使用 typeof 来判断其具体类型。

typeof的返回值是一个字符串, 用来说明变量的数据类型。typeof 一般只能返回如下几个结果: number, boolean, string, function, object, undefined。对于 Array, Null 等特殊对象使用 typeof 一律返回 object, 这正是 typeof 的局限性。| 参考:typeof和instanceof的区别是什么-CSDN博客

下面这些方法是判断数组的几种方法:

1、通过 instanceof 运算符判断

instanceof运算符用于检验构造函数的prototype属性是否出现在某个对象的原型链中的任何位置,返回一个布尔值。| 参考:typeof和instanceof的区别是什么 - CSDN博客

let arr1 = [1,2,3];
console.log(arr1 instanceof Array); //true
let arr2 = {};
arr2 instanceof Array; //false

//instanceof 运算符检测Array.prototype属性是否存在于变量arr1的原型链上
//显然arr1是一个数组,拥有Array.prototype属性,所以为true

2、通过 constructor 构造函数属性判断

实例的构造函数属性 constructor 指向构造函数,通过constructor属性可以判断是否为一个数组

let arr = [1,2,3];
console.log(arr.constructor == Array); //true

3、通过 Object.prototype.toString.call() 方法判断

Object.prototype.toString.call()可以获取到对象的不同类型

把对象转化成字符串和一个已知的对象进行对比。

let arr = [1,2,3];
console.log(Object.prototype.toString.call(arr) == '[object Array]'); //true

4、通过 Array.isArray() 判断

Array.isArray()用于确定传递的值是否是一个数组,返回一个布尔值。

isArray() 方法是ES5新增数组方法

let arr = [1,2,3];
console.log(Array.isArray(arr));  //true

5、通过Array原型链上的 isPrototypeOf() 方法判断

Array.prototype表示Array的构造函数的原型

isPrototypeOf()方法可以判断当前对象是否是另一个对象的原型,或者说一个对象是否被包含在另一个对象的原型链中)

let arr = [1,2,3];
console.log(Array.prototype.isPrototypeOf(arr)); //true

6、通过 Object.getPrototypeOf() 方法判断

Object.getPrototypeOf() 方法返回指定对象(arr)的原型,然后和Array的原型对比。

let arr = [1,2,3];
console.log(Object.getPrototypeOf(arr) == Array.prototype); //true

●总结● ——判断数组的方法主要有以下几种

  1. 使用instanceof运算符‌:通过检查对象的原型链中是否存在某个构造函数的prototype属性来判断。例如,array instanceof Array可以判断一个对象是否为数组‌。

  2. 使用constructor属性‌:通过检查对象的constructor属性是否指向Array构造函数来判断。例如,array.constructor === Array可以判断一个对象是否为数组‌。

  3. 使用Object.prototype.toString.call()方法‌:通过调用Object.prototype.toString.call()方法并将结果与[object Array]进行比较来判断。例如,Object.prototype.toString.call(array) === '[object Array]'可以判断一个对象是否为数组‌。

  4. 使用Array.isArray()方法‌:这是ES5引入的方法,可以直接判断一个对象是否为数组。例如,Array.isArray(array)可以判断一个对象是否为数组‌。

  5. 使用isPrototypeOf()方法‌:通过检查对象的原型是否为Array.prototype来判断。例如,Array.prototype.isPrototypeOf(array)可以判断一个对象是否为数组。

  6. 使用Object.getPrototypeOf()方法‌:通过比较对象的原型与Array.prototype来判断。例如,Object.getPrototypeOf(array) === Array.prototype可以判断一个对象是否为数组‌。

补充说明‌:

  • instanceof运算符和constructor属性在判断数组时较为常用,但需要注意它们可能受到原型链污染的影响。
  • Array.isArray()方法是ES5引入的,能够更准确地判断一个对象是否为数组,且不受原型链污染的影响。
  • Object.prototype.toString.call()isPrototypeOf()Object.getPrototypeOf()方法提供了更底层和准确的判断方式,但在日常开发中较少使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2193913.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于51单片机的多路电压测量proteus仿真

地址:https://pan.baidu.com/s/1cpgtfl571DcKfjhKvcKqSA 提取码:1234 仿真图: 芯片/模块的特点: AT89C52/AT89C51简介: AT89C52/AT89C51是一款经典的8位单片机,是意法半导体(STMicroelectron…

设计模式~~~

简单工厂模式(静态工厂模式) 工厂方法模式 抽象工厂角色 具体工厂角色

分词的艺术:为AI拆解文本

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

基于 springboot vue中学生日常行为评分管理系统设计与实现

博主介绍:专注于Java(springboot ssm 等开发框架) vue .net php python(flask Django) 小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找…

鸿蒙next开发者第一课02.DevEcoStudio的使用-习题

【习题】DevEco Studio的使用 通过/及格分80/ 满分100 判断题 1. 如果代码中涉及到一些网络、数据库、传感器等功能的开发,均可使用预览器进行预览。F 正确(True)错误(False) 预览器不能进行传感器等特殊功能的开发,需要使用真机开发 2. module.json5文件中的…

Day03-数据库服务管理语句

Day03-数据库服务管理语句 1、数据库服务语句分类1.1 什么是SQL语句1.2 SQL规范标准1.3 SQL语句分类 2、数据库服务字符设置2.1 为什么要有字符编码设置(避免中文乱码)--为什么中文会乱码?2.2 数据库中常用的字符编码以及区别2.3 数据库中如何…

Python | Leetcode Python题解之第461题汉明距离

题目: 题解: class Solution:def hammingDistance(self, x, y):ret 0bx, by bin(x)[2:].zfill(32), bin(y)[2:].zfill(32)for i in range(32):if bx[i] ! by[i]:ret 1return ret

全网最适合入门的面向对象编程教程:56 Python字符串与序列化-正则表达式和re模块应用

全网最适合入门的面向对象编程教程:56 Python 字符串与序列化-正则表达式和 re 模块应用 摘要: Python 的 re 模块提供了强大的正则表达式操作功能,用于在字符串中搜索、匹配、替换等,正则表达式是一种匹配字符串的模式。通过正则…

VAD 论文学习

VAD: Vectorized Scene Representation for Efficient Autonomous Driving 解决了什么问题?相关工作感知运动预测规划 提出了什么方法?概览1. 矢量化的场景学习矢量化地图交通参与者的矢量化运动 2. Planning via Interaction自车-其它交通参与者的交流自…

51单片机的水质检测系统【proteus仿真+程序+报告+原理图+演示视频】

1、主要功能 该系统由AT89C51/STC89C52单片机LCD1602显示模块温度传感器ph传感器浑浊度传感器蓝牙继电器LED、按键和蜂鸣器等模块构成。适用于水质监测系统,含检测和调整水温、浑浊度、ph等相似项目。 可实现功能: 1、LCD1602实时显示水温、水体ph和浑浊度 2、温…

YOLO11改进|注意力机制篇|引入并行分块注意力机制PPA

目录 一、【PPA】注意力机制1.1【PPA】注意力介绍1.2【PPA】核心代码 二、添加【PPA】注意力机制2.1STEP12.2STEP22.3STEP32.4STEP4 三、yaml文件与运行3.1yaml文件3.2运行成功截图 一、【PPA】注意力机制 1.1【PPA】注意力介绍 下图是PPA并行分块注意力机制结构图&#xff0c…

Taipy:AI应用全栈开发神器

Taipy 是一个免费使用的 Python 库,任何具备基本 Python 技能的人都可以使用。它是数据科学家、机器学习工程师和 Python 程序员的得力工具。使用 Taipy,你可以轻松地将数据和机器学习模型转换为功能齐全的 Web 应用程序。在我们生活的瞬息万变的世界中&…

消费者Rebalance机制

优质博文:IT-BLOG-CN 一、消费者Rebalance机制 在Apache Kafka中,消费者组 Consumer Group会在以下几种情况下发生重新平衡Rebalance: 【1】消费者加入或离开消费者组: 当一个新的消费者加入消费者组或一个现有的消费者离开消费…

springboot工程中使用tcp协议

文章目录 一、概述二、实现思路三、代码结构四、代码放送五、运行界面六. 主要技术点 一、概述 在上文JAVA TCP协议初体验 中,我们使用java实现了tcp协议的一个雏形,实际中大部分项目都已采用springboot,那么,怎么在springboot中…

【机器学习】知识总结1(人工智能、机器学习、深度学习、贝叶斯、回归分析)

目录 一、机器学习、深度学习 1.人工智能 1.1人工智能概念 1.2人工智能的主要研究内容与应用领域 1.2.1主要研究内容: 1.2.2应用领域 2.机器学习 2.1机器学习的概念 2.2机器学习的基本思路 2.3机器学习的分类 3.深度学习 3.1深度学习的概念 3.2人工智能…

Cocos_鼠标滚轮放缩地图

文章目录 前言一、环境二、版本一_code2.分析类属性方法详细分析详细分析onLoad()onMouseWheel(event)详细分析 总结 前言 学习笔记,请多多斧正。 一、环境 通过精灵rect放置脚本实现鼠标滚轮放缩地图。 二、版本一_code import { _decorator, Component, Node }…

task【XTuner微调个人小助手认知】

1 微调前置基础 本节主要重点是带领大家实现个人小助手微调,如果想了解微调相关的基本概念,可以访问XTuner微调前置基础。 2 准备工作 环境安装:我们想要用简单易上手的微调工具包 XTuner 来对模型进行微调的话,第一步是安装 XTu…

Trie树之最大异或对问题

这是C算法基础-数据结构专栏的第二十八篇文章,专栏详情请见此处。 从这篇博客开始,文章将会于每周一更新,望周知! 引入 上次,我们学习了Trie树之字符串统计问题,字符串统计问题中的Trie树节点存储的是字符…

面试官:如何实现分布式系统的限流?

限流的概念以及作用我前一篇文章已经做了介绍:并发限流算法的实践 目录 限流的几种算法 : 1、令牌桶算法 2、漏桶算法 3. 滑动时间窗口计数器算法 5. 全局限流 6. 客户端限流 7. API网关限流 8. 熔断与降级 本篇重点: 具体实现: 限流的几种算法 : 这里主要讲在分…

快速熟悉Nginx

一、Nginx是什么? ‌Nginx是一款高性能、轻量级的Web服务器和反向代理服务器。‌ ‌特点‌:Nginx采用事件驱动的异步非阻塞处理框架,内存占用少,并发能力强,资源消耗低。‌功能‌:Nginx主要用作静态文件服…