当前位置: 首页 > article >正文

前端必知必会-JavaScript数组方法(上)

文章目录

  • JavaScript数组方法
    • JavaScript 数组长度
    • JavaScript 数组 toString()
    • JavaScript 数组 at()
    • JavaScript 数组 join()
    • 弹出和推送
      • JavaScript 数组 pop()
      • JavaScript 数组 push()
    • 移动元素
      • JavaScript 数组 shift()
      • JavaScript 数组 unshift()
    • 更改元素
    • JavaScript 数组长度
    • JavaScript 数组 delete()
    • 合并数组(连接)
    • JavaScript 数组 concat()
  • 总结


JavaScript数组方法

JavaScript 数组长度

length 属性返回数组的长度(大小):

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let size = fruit.length;

JavaScript 数组 toString()

JavaScript 方法 toString() 将数组转换为(逗号分隔的)数组值字符串。

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
document.getElementById("demo").innerHTML = fruit.toString();

结果:

Banana,Orange,Apple,Mango

JavaScript 数组 at()

ES2022 引入了数组方法 at():

示例
使用 at() 获取水果的第三个元素:

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let fruit = fruit.at(2);

使用 [] 获取水果的第三个元素:

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let fruit = fruit[2];

at() 方法从数组返回索引元素。

at() 方法返回与 [] 相同的结果。

自 2022 年 3 月起,所有现代浏览器均支持 at() 方法:

注意
许多语言允许使用负括号索引(如 [-1])从对象/数组/字符串的末尾访问元素。

这在 JavaScript 中是不可能的,因为 [] 用于访问数组和对象。 obj[-1] 指的是键 -1 的值,而不是对象的最后一个属性。

ES2022 中引入了 at() 方法来解决这个问题。

JavaScript 数组 join()

join() 方法还将所有数组元素合并为一个字符串。

它的行为与 toString() 类似,但此外您还可以指定分隔符:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
document.getElementById("demo").innerHTML = fruit.join(" * ");

结果:

Banana * Orange * Apple * Mango

弹出和推送

使用数组时,可以轻松删除元素并添加新元素。

弹出和推送就是这样:

从数组中弹出项目,或将项目推送到数组中。

JavaScript 数组 pop()

pop() 方法从数组中删除最后一个元素:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit.pop();

pop() 方法返回“弹出”的值:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let fruit = fruit.pop();

JavaScript 数组 push()

push() 方法将新元素添加到数组(末尾):

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit.push("Kiwi");

push() 方法返回新数组的长度:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let length = fruit.push("Kiwi");

移动元素

移动相当于弹出,但作用于第一个元素而不是最后一个元素。

JavaScript 数组 shift()

shift() 方法删除第一个数组元素并将所有其他元素“移动”到较低的索引。

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit.shift();

shift() 方法返回“移出”的值:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
let fruit = fruit.shift();

JavaScript 数组 unshift()

unshift() 方法将新元素添加到数组(在开头),并“取消移位”旧元素:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit.unshift("Lemon");

unshift() 方法返回新数组长度:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit.unshift("Lemon");

更改元素

数组元素使用其索引号进行访问:

数组索引从 0 开始:

[0] 是第一个数组元素
[1] 是第二个
[2] 是第三个…

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit[0] = "Kiwi";

JavaScript 数组长度

length 属性提供了一种将新元素附加到数组的简便方法:

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
fruit[fruits.length] = "Kiwi";

JavaScript 数组 delete()

警告!
使用 delete() 会在数组中留下未定义的空洞。

请改用 pop() 或 shift()。

示例

const fruit = ["Banana", "Orange", "Apple", "Mango"];
delete fruit[0];

合并数组(连接)

在编程语言中,连接意味着将字符串首尾相连。

将“snow”和“ball”连接起来得到“snowball”。

连接数组意味着将数组首尾相连。

JavaScript 数组 concat()

concat() 方法通过合并(连接)现有数组来创建新数组:

示例(合并两个数组)

const myGirls = ["Cecilie", "Lone"];
const myBoys = ["Emil", "Tobias", "Linus"];

const myChildren = myGirls.concat(myBoys);

注意
concat() 方法不会更改现有数组。它始终返回一个新数组。

concat() 方法可以接受任意数量的数组参数。

示例(合并三个数组)

const arr1 = ["Cecilie", "Lone"];
const arr2 = ["Emil", "Tobias", "Linus"];
const arr3 = ["Robin", "Morgan"];
const myChildren = arr1.concat(arr2, arr3);

concat() 方法还可以将字符串作为参数:

示例(将数组与值合并)

const arr1 = ["Emil", "Tobias","Linus"];
const myChildren = arr1.concat("Peter");

总结

本文介绍了JavaScript数组方法(上)的使用,如有问题欢迎私信和评论


http://www.kler.cn/a/386264.html

相关文章:

  • 51c嵌入式~单片机合集2
  • 解读Nature:Larger and more instructable language models become less reliable
  • 网络技术-网桥模式
  • 万字长文解读深度学习——生成对抗网络GAN
  • 如何在CentOS 7上搭建SMB服务
  • 越南很火的slots游戏投放Google谷歌广告策略
  • GitHub中搜索项目方法
  • 【学习笔记】Kylin-Desktop-V10-SP1 麒麟系统知识5——网络设置
  • 从入门到精通:如何在Vue项目中有效运用el-image-viewer
  • 网络自动化03:简单解释send_config_set方法并举例
  • Docker 基础命令简介
  • Hive 实现查询用户连续三天登录记录
  • 【Ubuntu学习】Ubuntu无法使用vim命令编辑
  • 线程隔离和熔断降级并配置对应的服务降级
  • Wecom酱搭建企业微信发送消息
  • Leetcode:26. 删除有序数组中的重复项——Java快慢指针暴力解法
  • 华为云计算HCIE-Cloud Computing V3.0试验考试北京考场经验分享
  • 实战项目:通过自我学习让AI学习五子棋 - 1 - 项目定义
  • 【C语言】文件操作(超万字解析+形象图解)
  • Jest进阶知识:React组件的单元测试
  • 万字长文详解JavaScript基础语法--前端--前端样式--JavaWeb
  • redis 写入权限配置
  • 常用的 Lambda 表达式案例解析
  • 《 C++ 修炼全景指南:十九 》想懂数据库?深入 B 树的世界,揭示高效存储背后的逻辑
  • 不加锁解决线程安全
  • AWS账号安全:如何防范与应对账号被盗风险