解锁 JavaScript 数组的强大功能:常用方法和属性详解(下)

news2024/11/18 11:29:45

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 三、Array的常用方法
    • `filter()`方法:过滤出符合条件的数组元素
    • `map()`方法:对数组元素进行操作并返回新的数组
    • `reduce()`和`reduceRight()`方法:聚合数组元素
    • `forEach()`方法:遍历数组并对每个元素执行指定的操作
  • 四、`Array`的常用属性
    • `length`属性:获取数组中元素的数量
    • `prototype`属性:用于实现继承和共享方法
  • 五、总结
    • 总结`Array`的常用方法和属性的重要性和用途

三、Array的常用方法

filter()方法:过滤出符合条件的数组元素

filter() 方法是用于过滤出符合条件的数组元素的常用方法。它是 JavaScript 数组的一个内置方法,接受一个回调函数作为参数,并返回一个新的数组,其中包含通过测试的元素。以下是 filter() 方法的一些特点和示例:

  1. 回调函数:filter() 方法接受一个回调函数作为参数,该回调函数会被应用到数组的每个元素上。如果回调函数返回 true,则该元素将被包含在过滤后的新数组中。

  2. 不改变原始数组:filter() 方法不会改变原始数组本身,而是返回一个新的数组,其中包含通过测试的元素。

  3. 示例:

let array = [1, 2, 3, 4, 5];
let filteredArray = array.filter(function(element) {
    return element > 3;
});
console.log(filteredArray); 

在上面的示例中,使用 filter() 方法创建了一个新的数组 filteredArray,其中只包含原始数组中大于 3 的元素。

filter() 方法是一种强大的数组操作工具,可用于根据条件筛选和提取数组中的元素。它常与其他数组方法结合使用,以实现更复杂的数据处理和操作。

map()方法:对数组元素进行操作并返回新的数组

map() 方法是用于对数组元素进行操作并返回新的数组的常用方法。它是 JavaScript 数组的一个内置方法,接受一个回调函数作为参数,并将该回调函数应用到数组的每个元素上。以下是 map() 方法的一些特点和示例:

  1. 回调函数:map() 方法接受一个回调函数作为参数,该回调函数会被应用到数组的每个元素上。回调函数接受三个参数:当前处理的元素、当前元素的索引和整个数组本身。

  2. 返回新的数组:map() 方法会对每个元素应用回调函数,并将返回值存储在新的数组中。原始数组不会被改变。

  3. 示例:

let array = [1, 2, 3, 4, 5];
let mappedArray = array.map(function(element) {
    return element * 2;
});
console.log(mappedArray); 

在上面的示例中,使用 map() 方法将原始数组中的每个元素乘以 2,并将结果存储在新的数组 mappedArray 中。

map() 方法是一种强大的数组操作工具,它允许你对数组进行批量处理和转换操作。它常用于数据处理、数据映射和其他数组元素的操作。

reduce()reduceRight()方法:聚合数组元素

reduce()reduceRight() 方法是用于聚合数组元素的常用方法。它们是 JavaScript 数组的内置方法,用于将数组中的所有元素进行聚合操作,并返回一个最终结果。以下是这两个方法的简要说明:

  1. reduce() 方法:从数组的第一个元素开始,依次将每个元素与一个累积值(初始值)进行聚合操作,将每次操作的结果作为新的累积值,直到处理完整个数组。最终返回累积值的结果。

  2. reduceRight() 方法:与 reduce() 方法类似,但它从数组的最后一个元素开始,依次将每个元素与一个累积值(初始值)进行聚合操作,将每次操作的结果作为新的累积值,直到处理完整个数组。最终返回累积值的结果。

这两个方法都接受一个回调函数作为参数,该回调函数接受两个参数:累积值和当前处理的元素。回调函数负责进行聚合操作,并返回新的累积值。以下是一个示例,展示如何使用 reduce() 方法对数组进行求和:

let array = [1, 2, 3, 4, 5];
let sum = array.reduce(function(a, b) {
    return a + b;
});
console.log(sum); 

在上面的示例中,使用 reduce() 方法将数组中的所有元素相加,并将结果存储在变量 sum 中。

reduce()reduceRight() 方法提供了一种简洁的方式来聚合数组元素,并可以应用各种聚合操作,如求和、求平均值、最大值、最小值等。它们在处理数组数据时非常有用。

forEach()方法:遍历数组并对每个元素执行指定的操作

forEach() 方法是用于遍历数组并对每个元素执行指定操作的常用方法。它是 JavaScript 数组的一个内置方法。以下是 forEach() 方法的一些特点和示例:

  1. 语法:forEach() 方法接受一个回调函数作为参数,并将该回调函数应用到数组的每个元素上。

  2. 不返回值:forEach() 方法本身不返回任何值,它主要用于对数组进行迭代和操作。

  3. 示例:

let array = [1, 2, 3, 4, 5];
array.forEach(function(element) {
    console.log(element);
});

在上面的示例中,使用 forEach() 方法遍历数组 array,并在每次迭代时将当前元素打印到控制台上。

forEach() 方法是一种用于遍历数组并对每个元素执行操作的简单方式。它常用于数据处理、事件监听、动画循环等场景。需要注意的是,forEach() 方法无法中途退出循环,并且对原始数组进行的修改可能会影响到遍历过程。如果需要在遍历过程中进行条件判断或提前退出,可以考虑使用其他方法,如 for 循环或 filter() 方法。

四、Array的常用属性

length属性:获取数组中元素的数量

length 属性是用于获取数组中元素数量的属性。它是数组的一个固有属性,返回数组中元素的个数。以下是 length 属性的一些特点和示例:

  1. 返回值:length 属性返回一个整数,表示数组中元素的数量。

  2. 示例:

let array = [1, 2, 3, 4, 5];
let length = array.length;
console.log(length); 

在上面的示例中,创建了一个包含 5 个元素的数组 array,然后通过 length 属性获取数组中元素的数量,并将结果存储在变量 length 中。

length 属性是一个简洁的方式来获取数组的大小或元素数量。它可以用于确定数组的边界、循环迭代的次数、判断数组是否为空等操作。需要注意的是,length 属性是只读的,你不能通过设置它来改变数组的长度。如果需要修改数组的长度,可以使用其他方法,如 push()pop()slice() 等来操作数组。

prototype属性:用于实现继承和共享方法

prototype 属性在 JavaScript 中用于实现继承和共享方法。它是每个构造函数的一个属性,指向一个对象,这个对象包含可以被实例共享的属性和方法。以下是 prototype 属性的一些特点和示例:

  1. 作用:通过 prototype 属性,构造函数可以为其创建的实例共享属性和方法,从而实现继承和代码重用。

  2. 示例:

function Person(name) {
    this.name = name;
}
// 在 Person 构造函数的prototype对象上添加方法
Person.prototype.sayHello = function() {
    console.log("Hello, my name is " + this.name);
};
let person1 = new Person("Alice");
let person2 = new Person("Bob");
person1.sayHello(); 
person2.sayHello(); 

在上面的示例中,创建了一个 Person 构造函数,它接收一个参数 name,并将其赋值给实例的 name 属性。然后,通过在 Person.prototype 对象上添加了一个名为 sayHello 的方法,使得所有通过 new Person() 创建的实例都共享这个方法。

prototype 属性允许你在构造函数的外部定义方法,并使这些方法在所有实例中可用。它提供了一种简洁的方式来实现继承和共享行为,减少代码的冗余。需要注意的是,通过 prototype 共享的方法是在运行时动态绑定到实例上的,而不是在编译时确定的。这意味着,当你在实例上调用共享方法时,JavaScript 会自动查找并调用 prototype 对象上的相应方法。

五、总结

总结Array的常用方法和属性的重要性和用途

JavaScript 中的 Array 是一种常见的数据结构,用于存储多个值。它提供了许多常用的方法和属性,这些方法和属性对于操作和处理数组非常重要。以下是一些 Array 的常用方法和属性的总结:

  1. length 属性length 属性用于获取数组中元素的数量。它是一个可读可写的属性,可以用来动态调整数组的大小。

  2. push() 方法push() 方法用于向数组的末尾添加一个或多个元素。它可以接受任意数量的参数,并将它们依次添加到数组的末尾。

  3. pop() 方法pop() 方法用于删除数组的最后一个元素,并返回被删除的元素。如果数组为空,则返回 undefined

  4. unshift() 方法unshift() 方法用于向数组的开头添加一个或多个元素。它会将参数添加到数组的开头,并相应地调整数组的长度。

  5. shift() 方法shift() 方法用于删除数组的第一个元素,并返回被删除的元素。如果数组为空,则返回 undefined

  6. slice() 方法slice() 方法用于创建一个新的数组副本,其中包含从原始数组中选择的元素。它接受两个参数:起始索引和结束索引(不包括结束索引)。

  7. concat() 方法concat() 方法用于将一个或多个数组连接到原始数组的末尾,返回一个新的合并后的数组。

  8. indexOf() 方法indexOf() 方法用于查找数组中第一个出现的指定元素的索引。如果未找到,则返回 -1

  9. filter() 方法filter() 方法用于创建一个新的数组,其中包含通过提供的函数实现的测试的原始数组的元素。

这些方法和属性在处理数组时非常有用,可以实现对数组的增删改查、连接、截取等操作。它们使数组的操作更加灵活和高效,并且可以根据具体需求选择合适的方法来处理数组数据。

了解和掌握这些方法和属性对于编写有效的 JavaScript 代码处理数组是至关重要的。它们提供了对数组的基本操作和功能,可以帮助你更好地管理和操作数组中的数据。

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

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

相关文章

SpringFramework实战指南(一)

SpringFramework实战指南(一) 一、技术体系结构1.1 总体技术体系1.2 框架概念和理解 一、技术体系结构 1.1 总体技术体系 单一架构 一个项目,一个工程,导出为一个war包,在一个Tomcat上运行。也叫all in one。 单一架…

Redis常见命令、数据类型

我们可以通过Redis的中文文档:Redis命令中心(Redis commands) -- Redis中国用户组(CRUG),来学习各种命令。 也可以通过菜鸟教程官网来学习:Redis 键(key) | 菜鸟教程 一、Redis数据结构介绍 Red…

UML-顺序图

提示:用例图从参与者的角度出发,描述了系统的需求(用例图);静态图定义系统中的类和对象间的静态关系(类图、对象图和包图);状态机模型描述系统元素的行为和状态变化流程(…

快速入门Java NIO(New I/O)的网络通信框架--Netty

Netty 入门 了解netty前需要对nio有一定认识,该笔记基础来自bilinbili黑马,在此基础上自己学习的笔记,添加了一些自己的理解 了解java 非阻塞io编程 1. 概述 1.1 Netty 是什么? Netty is an asynchronous event-driven network application framework for rapid …

关于AMC8模拟考试延长到1月19日14点,以及常见的几个新问题

相信过去的周末两天,很多参加今年AMC8美国数学思维竞赛活动的孩子们都参加了AMC8模拟考试。昨天有家长问六分成长,周末两天因故没能参加要不要紧?如果还想参加怎么办? 不用担心!官方已经把AMC8模拟考试的时间延长到1月…

【Redis】AOF 源码

在上篇, 我们已经从使用 / 机制 / AOF 过程中涉及的辅助功能等方面简单了解了 Redis AOF。 这篇将从源码的形式, 进行深入的了解。 1 Redis 整个 AOF 主要功能 Redis 的 AOF 功能概括起来就 2 个功能 AOF 同步: 将客户端发送的变更命令, 保存到 AOF 文件中AOF 重写: 随着 Red…

Python 潮流周刊#35:Python JIT 编译器和 Numpy2 即将推出

△△请给“Python猫”加星标 ,以免错过文章推送 你好,我是猫哥。这里每周分享优质的 Python、AI 及通用技术内容,大部分为英文。本周刊开源,欢迎投稿[1]。另有电报频道[2]作为副刊,补充发布更加丰富的资讯,…

【Java SE语法篇】9.抽象类和接口

📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 文章目录 1. 抽象类1.1 抽象类的概念1.2 抽象类的语法1.3 抽象…

VScode设置自动添加自定义注释及修改字体

首先安装snippet mac可以键入commanp,输出> 选择自己所需的需要自动添加的文件类型配置文件 安装自己的需要修改 "Print to console": {"prefix": "xx", // 自己键入内容"body": [ // 注释信息"// xxx …

【NI国产替代】USB‑7846 Kintex-7 160T FPGA,500 kS/s多功能可重配置I/O设备

Kintex-7 160T FPGA,500 kS/s多功能可重配置I/O设备 USB‑7846具有用户可编程FPGA,可用于高性能板载处理和对I/O信号进行直接控制,以确保系统定时和同步的完全灵活性。 您可以使用LabVIEW FPGA模块自定义这些设备,开发需要精确定时…

canvas创建图像数据,并在画布上展示

查看专栏目录 canvas示例教程100专栏,提供canvas的基础知识,高级动画,相关应用扩展等信息。canvas作为html的一部分,是图像图标地图可视化的一个重要的基础,学好了canvas,在其他的一些应用上将会起到非常重…

Python学习从0到1 day4 python格式化输出和输入方法

其实我不是我,我是青山辽阔 ——24.1.14 一、百分号形式的格式化输出 1.普通输出 #1.定义一些变量 name 陈浩南 age 25 address 广州市天河区#2.变量的输出(普通输出) print(name) print(age) print(address)#3.Python中,还允…

【矩阵快速幂】封装类及测试用例及样例

作者推荐 视频算法专题 通俗的说&#xff0c;就是矩阵的乘方。 封装类 核心代码 class CMat { public:// 矩阵乘法static vector<vector<long long>> multiply(const vector<vector<long long>>& a, const vector<vector<long long>…

八:分布式锁

1、为什么要使用分布式锁 锁是多线程代码中的概念&#xff0c;只有多任务访问同一个互斥的共享资源时才需要锁。单机应用开发时一般使用synchronized或lock。多线程的运行都是在同一个JVM之下。应用是分布式集群&#xff0c;属于多JVM的工作环境&#xff0c;JVM之间已经无法通过…

【Golang开源项目】Golang高性能内存缓存库BigCache设计与分析

项目地址 BigCache 是一个快速&#xff0c;支持并发访问&#xff0c;自淘汰的内存型缓存&#xff0c;可以在存储大量元素时依然保持高性能。BigCache将元素保存在堆上却避免了GC的开销。 背景介绍 BigCache的作者在项目里遇到了如下的需求&#xff1a; 支持http协议支持 10…

【RT-DETR改进涨点】为什么YOLO版本的RT-DETR训练模型不收敛的问题

前言 大家好&#xff0c;我是Snu77&#xff0c;这里是RT-DETR有效涨点专栏。 本专栏的内容为根据ultralytics版本的RT-DETR进行改进&#xff0c;内容持续更新&#xff0c;每周更新文章数量3-10篇。 其中提到的多个版本ResNet18、ResNet34、ResNet50、ResNet101为本人根据RT-…

Linux|centos7操作系统|VMware虚拟机安装水星免驱USB网卡8188gu记录

引言&#xff1a; 最近对于嵌入式系统比较感兴趣&#xff0c;因此&#xff0c;计划先使用VMware workstation虚拟机试一试Linux系统下的网卡驱动安装 这不试不知道&#xff0c;一试吓一跳&#xff0c;发现Linux下的驱动安装还是比较麻烦的&#xff0c;下面将就本次的Linux系统…

详解SpringCloud微服务技术栈:强推!源码跟踪分析Ribbon负载均衡原理、Eureka服务部署

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位大四、研0学生&#xff0c;正在努力准备大四暑假的实习 &#x1f30c;上期文章&#xff1a;详解SpringCloud微服务技术栈&#xff1a;认识微服务、服务拆分与远程调用 &#x1f4da;订阅专栏&#xff1a;微服务技术全家桶…

【LangChain学习之旅】—(6) 提示工程(下):用思维链和思维树提升模型思考质量

【LangChain学习之旅】—&#xff08;6&#xff09; 提示工程&#xff08;下&#xff09;&#xff1a;用思维链和思维树提升模型思考质量 什么是 Chain of ThoughtFew-Shot CoTZero-Shot CoTChain of Thought 实战CoT 的模板设计程序的完整框架Tree of Thought总结 Reference&a…

UE5 伤害数字跳出

学习视频 大体思路&#xff1a; 1.创建一个控件蓝图。 播放动画&#xff0c;K透明度&#xff0c;文本位置。 2.创建一个控件组件。 类默认值中设置。 3.在位置处创建组件实例 自定义事件略。