JavaScript数组的应用及实战

news2024/11/26 11:35:59

 🎬 岸边的风:个人主页

 🔥 个人专栏 :《 VUE 》 《 javaScript 》

⛺️ 生活的理想,就是为了理想的生活 !

在这里插入图片描述

 

目录

引言

1. 数组简介

2. 数组方法API

添加和删除元素

修改和访问元素

数组遍历

数组转换和连接

数组排序和搜索

其他常用方法

3. 数组属性

4. 实现数组API

实现添加和删除元素的方法

实现修改和访问元素的方法

实现数组遍历的方法

实现数组转换和连接的方法

实现数组排序和搜索的方法

实现其他常用方法

5. 数组的应用场景


引言

在JavaScript中,数组(Array)是一种重要且广泛应用的数据结构,用于存储和操作一组有序的数据。JavaScript提供了丰富的数组方法和属性,使我们能够方便地对数组进行增删改查等操作。本文将详细介绍JavaScript数组的方法API、属性,并探讨如何模拟实现数组的API。此外,还将介绍数组的应用场景,帮助读者更好地理解和应用数组。

1. 数组简介

数组是一种有序的数据集合,它可以存储多个值,并根据索引访问和操作这些值。在JavaScript中,数组是一种动态类型的数据结构,可以容纳任意类型的数据,包括基本类型和对象。

JavaScript数组的特点包括:

  • 数组的长度是动态可变的,可以根据需要随时添加或删除元素。
  • 数组的索引是从0开始的,通过索引可以快速访问和修改数组中的元素。
  • 数组可以包含不同类型的元素,甚至可以嵌套包含其他数组。

JavaScript提供了许多方法和属性来操作和处理数组,使得数组成为处理数据的强大工具。

2. 数组方法API

JavaScript数组提供了丰富的方法来操作数组。

添加和删除元素

  • push():在数组末尾添加一个或多个元素,并返回新数组的长度。
  • pop():移除并返回数组的最后一个元素。
  • unshift():在数组开头添加一个或多个元素,并返回新数组的长度。
  • shift():移除并返回数组的第一个元素。
  • splice():从指定位置添加或删除元素。

修改和访问元素

  • slice():返回数组的一部分,不改变原数组。
  • concat():将多个数组合并为一个新数组。
  • join():将数组的元素连接成一个字符串。
  • reverse():颠倒数组中元素的顺序。
  • sort():对数组元素进行排序。

数组遍历

  • forEach():对数组的每个元素执行指定的操作。
  • map():创建一个新数组,其中的元素是原始数组经过指定操作后的结果。
  • filter():创建一个新数组,其中的元素是符合指定条件的原始数组元素。
  • reduce():对数组的元素进行累加或合并操作。

数组转换和连接

  • toString():将数组转换为字符串。
  • toLocaleString():将数组转换为本地化的字符串。
  • join():将数组的元素连接成一个字符串。

数组排序和搜索

  • sort():对数组元素进行排序。
  • reverse():颠倒数组中元素的顺序。
  • indexOf():返回指定元素在数组中首次出现的索引。
  • lastIndexOf():返回指定元素在数组中最后一次出现的索引。

其他常用方法

  • isArray():检测一个值是否为数组。
  • find():返回数组中符合指定条件的第一个元素。
  • findIndex():返回数组中符合指定条件的第一个元素的索引。
  • some():检测数组中是否至少有一个元素符合指定条件。
  • every():检测数组中是否所有元素都符合指定条件。

以上仅是JavaScript数组方法API的部分常用示例,更多详细的方法和用法请参考MDN Web Docsopen in new window。

3. 数组属性

JavaScript数组还有一些常用的属性,用于描述和操作数组的特性和状态。

  • length:返回数组的长度。
  • constructor:返回创建数组对象的原型函数。
  • prototype:数组对象的原型对象,用于添加新的方法和属性。

这些属性可以帮助我们了解数组的结构和信息,以便更好地处理和操作数组。

4. 实现数组API

为了更好地理解数组的方法和实现原理,我们可以尝试自己模拟实现一些数组API的方法。

实现添加和删除元素的方法

// 模拟实现 push() 方法
Array.prototype.myPush = function(...elements) {
  const len = this.length;
  let i = 0;
  while (i < elements.length) {
    this[len + i] = elements[i];
    i++;
  }
  return this.length;
};

// 模拟实现 pop() 方法
Array.prototype.myPop = function() {
  if (this

.length === 0) return undefined;
  const lastElement = this[this.length - 1];
  delete this[this.length - 1];
  this.length--;
  return lastElement;
};

// 模拟实现 unshift() 方法
Array.prototype.myUnshift = function(...elements) {
  const originalLength = this.length;
  for (let i = originalLength - 1; i >= 0; i--) {
    this[i + elements.length] = this[i];
  }
  for (let i = 0; i < elements.length; i++) {
    this[i] = elements[i];
  }
  this.length = originalLength + elements.length;
  return this.length;
};

// 模拟实现 shift() 方法
Array.prototype.myShift = function() {
  if (this.length === 0) return undefined;
  const firstElement = this[0];
  for (let i = 0; i < this.length - 1; i++) {
    this[i] = this[i + 1];
  }
  delete this[this.length - 1];
  this.length--;
  return firstElement;
};

// 示例使用
const myArray = [1, 2, 3];
console.log(myArray.myPush(4, 5));    // 输出:5
console.log(myArray);                  // 输出:[1, 2, 3, 4, 5]
console.log(myArray.myPop());        // 输出:5
console.log(myArray);                  // 输出:[1, 2, 3, 4]
console.log(myArray.myUnshift(0)); // 输出:5
console.log(myArray);                  // 输出:[0, 1, 2, 3, 4]
console.log(myArray.myShift());     // 输出:0
console.log(myArray);                  // 输出:[1, 2, 3, 4]

实现修改和访问元素的方法

// 模拟实现 splice() 方法
Array.prototype.mySplice = function(startIndex, deleteCount, ...elements) {
  const removedElements = [];
  const len = this.length;
  const deleteEndIndex = Math.min(startIndex + deleteCount, len);
  const moveCount = len - deleteEndIndex;

  // 保存删除的元素
  for (let i = startIndex; i < deleteEndIndex; i++) {
    removedElements.push(this[i]);
  }

  // 移动剩余元素
  for (let i = 0; i < moveCount; i++) {
    this[startIndex + deleteCount + i] = this[startIndex + deleteCount + i + moveCount];
  }

  // 插入新元素
  for (let i = 0; i < elements.length; i++) {
    this[startIndex + i] = elements[i];
  }

  // 更新长度
  this.length = len - deleteCount + elements.length;

  return removedElements;
};

// 示例使用
const myArray = [1, 2, 3, 4, 5];
console.log(myArray.mySplice(2, 2, 'a', 'b')); // 输出:[3, 4]
console.log(myArray);                             // 输出:[1, 2, 'a', 'b', 5]

实现数组遍历的方法

// 模拟实现 forEach() 方法
Array.prototype.myForEach = function(callbackFn) {
  for (let i = 0;

 i < this.length; i++) {
    callbackFn(this[i], i, this);
  }
};

// 模拟实现 map() 方法
Array.prototype.myMap = function(callbackFn) {
  const mappedArray = [];
  for (let i = 0; i < this.length; i++) {
    mappedArray.push(callbackFn(this[i], i, this));
  }
  return mappedArray;
};

// 示例使用
const myArray = [1, 2, 3];
myArray.myForEach((value, index) => {
  console.log(`Element at index ${index} is ${value}`);
});

const doubledArray = myArray.myMap(value => value * 2);
console.log(doubledArray);  // 输出:[2, 4, 6]

实现数组转换和连接的方法

// 模拟实现 toString() 方法
Array.prototype.myToString = function() {
  let result = '';
  for (let i = 0; i < this.length; i++) {
    if (i > 0) {
      result += ', ';
    }
    result += this[i];
  }
  return result;
};

// 模拟实现 join() 方法
Array.prototype.myJoin = function(separator = ',') {
  let result = '';
  for (let i = 0; i < this.length; i++) {
    if (i > 0) {
      result += separator;
    }
    result += this[i];
  }
  return result;
};

// 示例使用
const myArray = [1, 2, 3];
console.log(myArray.myToString());      // 输出:'1, 2, 3'
console.log(myArray.myJoin('-'));       // 输出:'1-2-3'

实现数组排序和搜索的方法

// 模拟实现 sort() 方法
Array.prototype.mySort = function(compareFn) {
  const length = this.length;
  for (let i = 0; i < length - 1; i++) {
    for (let j = 0; j < length - 1 - i; j++) {
      if (compareFn(this[j], this[j + 1]) > 0) {
        [this[j], this[j + 1]] = [this[j + 1], this[j]];
      }
    }
  }
  return this;
};

// 模拟实现 indexOf() 方法
Array.prototype.myIndexOf = function(searchElement, fromIndex = 0) {
  const length = this.length;
  for (let i = Math.max(fromIndex, 0); i < length; i++) {
    if (this[i] === searchElement) {
      return i;
    }
  }
  return -1;
};

// 示例使用
const myArray = [5, 2, 1, 4, 3];
console.log(myArray.mySort());        // 输出:[1, 2, 3, 4, 5]
console.log(myArray.myIndexOf(4));  // 输出:3

实现其他常用方法

// 模拟实现 isArray() 方法
Array.myIsArray = function(obj) {
  return Object.prototype.toString.call(obj) === '[object Array]';
};

// 模拟实现 find() 方法
Array.prototype.myFind = function(callbackFn) {
  for (let i = 0; i < this.length; i++) {
    if (callbackFn(this[i], i, this)) {


      return this[i];
    }
  }
  return undefined;
};

// 示例使用
const myArray = [1, 2, 3, 4, 5];
console.log(Array.myIsArray(myArray));    // 输出:true
console.log(myArray.myFind(value => value > 3)); // 输出:4

以上是一些简单的模拟实现示例,用于帮助理解数组方法的实现原理。

5. 数组的应用场景

数组作为一种常见的数据结构,在前端开发中有许多应用场景。

  • 数据存储和管理:数组可用于存储和管理数据集合,如用户列表、商品列表等。可以通过数组的增删改查操作,对数据进行增删改查、排序和搜索等操作。
  • 数据筛选和过滤:使用数组的过滤方法(如filter())可以方便地筛选和过滤数据,根据指定条件获取符合条件的数据子集。
  • 数据统计和计算:通过数组的迭代方法(如reduce())可以对数据进行统计和计算操作,如求和、平均值、最大值、最小值等。
  • 数据展示和渲染:使用数组和模板引擎可以方便地进行数据的展示和渲染,如动态生成列表、表格等页面元素。

数组在前端开发中的应用非常广泛,几乎涉及到数据的存储、处理和展示等方方面面

 

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

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

相关文章

IMU+摄像头实现无标记运动捕捉

惯性传感和计算机视觉的进步为在临床和自然环境中获得精准数据带来了新可能。然而在临床应用时需要仔细地将传感器与身体对齐&#xff0c;这减慢了数据收集过程。 随着无标记运动捕捉的发展&#xff0c;研究者们提出了一个新的深度学习模型&#xff0c;利用来自视觉、惯性传感…

BIO、NIO、AIO有什么区别

什么是IO Java中I/O是以流为基础进行数据的输入输出的&#xff0c;所有数据被串行化(所谓串行化就是数据要按顺序进行输入输出)写入输出流。简单来说就是java通过io流方式和外部设备进行交互。 在Java类库中&#xff0c;IO部分的内容是很庞大的&#xff0c;因为它涉及的领域很…

Spring框架@Autowired和@Resource到底有什么区别

目录 1 来源不同2.依赖查找顺序不同2.1 Autowired 查找顺序2.2 Resource 查找顺序2.3 查找顺序小结 3.支持的参数不同4.依赖注入的支持不同5.编译器提示不同6 总结 1 来源不同 Autowired 和 Resource 来自不同的“父类”&#xff0c;其中 Autowired 是 Spring 定义的注解&#…

从命令行管理文件

1.linux系统中硬盘文件存储原理 硬连接 1.1.原理 linux系统中允许多个文件指向同一个inode&#xff0c;即允许一个文件拥有多个有效的路径名和文件名。 理解:硬连接就是指向原始文件的inode指针 证明一&#xff1a; 创建一个文件t1 查看他的硬链接数 创建一个硬链接 …

一阶微分方程

目录 可分离变量的方程 齐次微分方程 一阶线性微分方程 伯努科方程 全微分方程 可分离变量的方程 可分离变量的方程是一种常见的一阶常微分方程类型&#xff0c;其特点是可以通过将变量分离到方程的两侧&#xff0c;从而可以分别对各自变量进行积分。一般形式的可分离变量…

武汉融资融券(两融)开户利率最低能做到多少?无门槛利率5%!

武汉融资融券(两融)开户利率最低能做到多少?无门槛利率5%! 具体武汉融资融券(两融)开户利率最低能做到多少&#xff0c;需要根据不同的券商政策而定。不同的券商可能具有不同的优惠政策和开户条件&#xff0c;因此开户前应该仔细了解券商的政策和条件。 融资融券是指投资者通…

Minio入门系列【2】纠删码

1 纠删码 Minio使用纠删码erasure code和校验和checksum来保护数据免受硬件故障和无声数据损坏。 即便丢失一半数量&#xff08;N/2&#xff09;的硬盘&#xff0c;仍然可以恢复数据 1.1 什么叫纠删码 纠删码是一种用于重建丢失或损坏数据的数学算法。 纠删码&#xff08;e…

SQL注入类型判断

SQL注入的类型分为字符型和数字型&#xff0c;以sqli-labs靶场1、2关为例&#xff1a; 文章目录 第一关第二关无错误回显的判断 第一关 第一关注入一个1’&#xff0c;错误回显出下面内容&#xff0c;其中1’是注入的内容&#xff0c;0,1后面的单引号和最前面的单引号是一对&am…

湖北中级工程师职称网上申报流程是怎么样?应该如何在网上填写申报信息呢?

现在湖北中级职称全部采取网上申报形式&#xff0c;不管是水测还是后面职称评审都是需要网上申报信息&#xff0c;那么中级职称评审&#xff0c;网上如何申报信息呢&#xff1f;填写信息的时候需要注意哪些方面呢&#xff1f;今天甘建二这边给大家整理一下&#xff0c;希望对大…

电动垂直起降飞行器的发展现状

摘要 近年来,电动垂直起降&#xff08;eVTOL&#xff09;飞行器在城市空运中得到快速发展。本文介绍了近5年来世界范围内主要的在研电动垂直起降飞行器项目,从飞行器布局形式、总体设计参数、推进系统类型、飞行控制等级等方面进行了归纳和总结,分析了不同构型下相应电动垂直起…

Redis 五大类型源码及底层实现

面试题&#xff1a; 谈谈Redis数据类型的底层数据结构&#xff1a; SDS动态字符串双向链表玉缩列表ziplist哈希表hashtable跳表kiplist整数集合intset快速列表quicklist紧凑列表listpack Redis源代码的核心部分 官网&#xff1a;GitHub - redis/redis: Redis is an in-memory…

jenkins自动化脚本集成时钉钉消息未发送

在进行jenkins自动化脚本集成时&#xff0c;需要配置钉钉发送消息。钉钉的配置正确&#xff0c;测试钉钉消息发送成功&#xff0c;但是当构建项目时&#xff0c;却没有收到钉钉消息&#xff0c;报错如下&#xff1a; [钉钉插件]发送消息时报错: java.lang.NullPointerExceptio…

项目经理晋升为企业高管,需要杀死自己三次

大家好&#xff0c;我是老原。 “猴子屁股理论”&#xff0c;大家应该都知道吧。 就拿职场来说&#xff0c;它就像是一棵树&#xff0c;从树底下开始爬&#xff0c;一层一层的基层员工-基层干部-中层干部-高层-老板。 你会发现&#xff0c;无论你在哪一层&#xff0c;往上看都…

PyTorch实战-实现神经网络图像分类基础Tensor最全操作详解(二)

前言 PyTorch可以说是三大主流框架中最适合初学者学习的了&#xff0c;相较于其他主流框架&#xff0c;PyTorch的简单易用性使其成为初学者们的首选。这样我想要强调的一点是&#xff0c;框架可以类比为编程语言&#xff0c;仅为我们实现项目效果的工具&#xff0c;也就是我们…

开始使用Filebeat

认识Beats Beats是用于单用途数据托运人的平台。它们以轻量级代理的形式安装&#xff0c;并将来自成百上千台机器的数据发送到Logstash或Elasticsearch。 &#xff08;画外音&#xff1a;通俗地理解&#xff0c;就是采集数据&#xff0c;并上报到Logstash或Elasticsearch&…

用matlab在hfss中建模

hfss可以导入vbs语言建模 怎么生成建模的vbs文档&#xff1f; 1.在hfss中建模建一遍 导出建模的vbs&#xff0c;然后笔记本打开vbs&#xff0c;需要改的话直接改。 参考 https://blog.csdn.net/m0_56117494/article/details/128007860 一文 这个方法朴实无华 但是需要写vbs语言…

英语单词(6)

1.person 人 2.start 开始 3.menu 菜单 4.login 登录 5.main 主要的 6.document 文档 7.display 显示 8.method 方法,条理 9.version 版本 10parameter 参数

Leecode1160: 拼写单词

直接使用一个哈希表存整体的结果&#xff0c;一个临时的哈希表每次算一遍&#xff0c;但是1是要设置标志位来判断最后是否正确并加上长度&#xff0c;2是千万要记得每次新建一个空间来存哈希表绝对不能不空间就等于&#xff0c;会出事&#xff01;&#xff01;

【小吉送书—第三期】Linux私教课:技术内核与企业运维篇

文章目录 &#x1f354;查找⭐find命令&#x1f388;按文件名&#x1f388;按拥有者&#x1f388;查找Linux系统下大于200M的文件 ⭐locate命令&#x1f388;使用方法 ⭐which命令&#xff08;查找指令的&#xff0c;而不是文件&#xff09;&#x1f388;使用方法 ⭐grep命令和…

Appium混合页面点击方法tap的使用

原生应用开发&#xff0c;是在Android、IOS等移动平台上利用官方提供的开发语言、开发类库、开发工具进行App开发&#xff1b;HTML5&#xff08;h5&#xff09;应用开发&#xff0c;是利用Web技术进行的App开发。目前&#xff0c;市面上很多app都是原生和h5混合开发&#xff0c…