网站首页 > 技术文章 正文
js对数组操作的方法
// 目标数组
const arr = [
{
id: 1,
name: 'zhangsan'
},
{
id: 2,
name: 'lisi'
}
]
push
往数组的末尾添加一条数据
arr.push({
id: 3,
name: '王五'
})
unshift
往数组的首部添加一条数据
arr.unshift({
id: 4,
name: '赵四'
})
pop
删除数组的最后一条数据
arr.pop()
shift
删除数组的第一天数据
arr.shift()
splice
既可以删除,也可以添加
// 删除
arr.splice(0, 1)
// 添加
arr.splice(0, 0, {
id: 4,
name: '李俊'
})
sort
对数组进行排序
arr.sort(function (a, b) {
return a.id - b.id // 升序
// return b.id - a.id // 倒序
})
以上方法会修改原数组
slice
对数组进行截取,返回一个新数组
const newArr = arr.slice(0, 2) // 第1个参数是截取的位置,第二个参数是截取几个
forEach
遍历数组,什么都不会返回,也不会修改原数组
arr.forEach(item => {
// 进行js逻辑操作
// ........
})
map
遍历数组,对数组的元素进行操作,然后返回一个新数组
const newArr = arr.map(item => {
item.num = parseInt(Math.random() * 10)
return item
})
const newArr2 = arr.map(item => {
return parseInt(Math.random() * 10)
})
filter
遍历数组,但是它的作用是根据条件过滤数组,
将符合条件的数组中的元素,添加到一个新数组中,并且返回新数组
const newArr = arr.filter(item => {
const flag = item.id === 2
return flag; // true: item就会添加到newArr中,false:item就不会添加
})
find
遍历数组,并且找到符合条件的那个元素
const ele = arr.find(item => {
const flag = item.id === 2;
return flag
})
/*
ele就是:
{
id: 2,
name: 'lisi'
}
*/
findIndex
遍历数组,并且找到符合条件的那个元素的索引值
const index = arr.find(item => {
const flag = item.id === 2;
return flag
})
// index: 1
some
遍历数组,只要有一个元素符合条件,就返回true,否则就返回false
const boo = arr.some(item => {
const flag = item.id === 2;
return flag
})
const boo2 = arr.some(item => {
const flag = item.id === 3;
return flag
})
every
遍历数组,每次遍历都符合条件,才会返回true,只要有一次遍历不符合条件,就返回false
const boo = arr.every(item => {
const flag = item.id > 0;
return flag
})
const boo2 = arr.every(item => {
const flag = item.id === 3;
return flag
})
includes
判断数组中是否包含某个元素,只适合原始类型的数据判断。
const arr2 = [1, true, 'abc']
arr2.includes(1) // true
arr2.includes(true) // true
arr2.includes('abc') // true
arr2.includes(5) // false
reduce
const arr = [1,2,3,4];
const sum = arr.reduce((target, item) => {
return target + item
}, 0)
const obj = {
a: {
b: {
c: 1
}
}
}
const str = 'a.b.c';
// 根据str获取对象数据
// 例如 str === 'a' 那就获取obj.a
// str === 'a.b' 那就获取obj.a.b
// str === 'a.b.c' 那就获取obj.a.b.c
const arr2 = str.split('.'); // ['a','b','c']
const res = arr2.reduce((target, item) => {
return target[item]
// 第一次 obj.a
// 第二次 obj.a.b
// 第三次 obj.a.b.c
}, obj)
猜你喜欢
- 2024-09-30 JavaScript数组_数组方法「二」(二十七)
- 2024-09-30 table组件,前端如何使用table组件打印数组数据
- 2024-09-30 前端数组改字符串方法 前端数组改字符串方法是什么
- 2024-09-30 javascript复制数组的三种方式 javascript复制粘贴
- 2024-09-30 第21节 检测数组、类数组及多维数组-Web前端开发之Javascript
- 2024-09-30 前端系列——ES6中循环数组的方法
- 2024-09-30 前端已死?请用TS写出20个数组方法的声明
- 2024-09-30 springboot项目中,前端如何传递一个自定义对象数组给后端
- 2024-09-30 带你走进javascript数组的世界 javascript数组操作方法
- 2024-09-30 每天学点 ES6 —— 数组(二) es6数组处理方法
你 发表评论:
欢迎- 最近发表
-
- 前端流行框架Vue3教程:13. 组件传递数据_Props
- 前端必看!10 个 Vue3 救命技巧,解决你 90% 的开发难题?
- JAVA和JavaScript到底是什么关系?是亲戚吗?
- Java和js有什么区别?(java和javascript的区别和联系)
- 东方标准|Web和Java的区别,如何选择这两个专业
- 前端面试题-JS 中如何实现大对象深度对比
- 360前端一面~面试题解析(360前端笔试)
- 加班秃头别慌!1 道 Vue 面试题,快速解锁大厂 offer 通关密码
- 焦虑深夜刷题!5 道高频 React 面试题,吃透 offer 稳了
- 2025Web前端面试题大全(整理版)面试题附答案详解,最全面详细
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)