vue 数组常用方法(总结)

2023-05-16

vue 数组常用方法

  • 操作原数组
    • push(item)
    • pop()
    • shift()
    • unshift(item,[...n])
    • splice(startIndex,[endIndex])
    • sort()
    • reverse()
  • 返回新数组
    • slice(startIndex,[endIndex])
    • concat()
    • filter()
    • map()
    • forEach()
    • find()
    • findIndex()
    • some()
    • every()
  • 其他方法
    • join('参数')
    • toString()
    • indexOf()
    • reduce(callback,initial)

操作原数组

push(item)

向数组的末尾添加一个或多个元素,并返回新的长度
item:第一个元素(必填)
…n:多个元素(选填)

let arr =[1, 2, 3];
arr.push(4,5);
console.log(arr);  // [1, 2, 3, 4,5]

pop()

删除数组的最后一个元素并返回删除的元素。改变数组的长度

let arr =[1, 2, 3];
let temp=arr.pop();
console.log(temp); // 3
console.log(arr); // [1, 2]

shift()

把数组的第一个元素从其中删除,并返回第一个元素的值。改变数组的长度

let arr =[1, 2, 3];
let temp=arr.shift();
console.log(temp); // 1
console.log(arr); // [2, 3]

unshift(item,[…n])

向数组的开头添加一个或更多元素,返回新的长度,并返回添加数组的最后一个元素。该方法将改变数组的数目
item:第一个元素(必填)
…n:多个元素(选填)

let arr =[1, 2, 3];
let temp=arr.unshift(4,5);
console.log(temp); // 5
console.log(arr); // [4, 5, 1, 2, 3]

splice(startIndex,[endIndex])

添加或删除数组中的元素。返回以数组形式表现的删除元素
startIndex:开始的下标位置(必填)
endIndex:结束的下标位置(选填,如果没有,会从开始下标到最后元素的下标)

let arr =[1, 2, 3];
let temp=arr.splice(1,1);
console.log(temp); // 2
console.log(arr); // [1, 3]

sort()

对数组的元素进行排序。排序顺序可以是字母或数字,并按升序或降序。默认排序顺序为按字母升序。当数字是按字母顺序排列时"40"将排在"5"前面。

let arr =[4, 1, 2, 3, 10, 21];
console.log(arr.sort()); // [1, 10, 2, 21, 3, 4]
console.log(arr); // [1, 10, 2, 21, 3, 4]

reverse()

用于颠倒数组中元素的顺序。

let arr =[1, 2, 3, 10, 21];
console.log(arr.reverse()); // [21, 10, 3, 2, 1]

返回新数组

slice(startIndex,[endIndex])

可提取字符串的某个部分,并以新的字符串返回被提取的部分
startIndex:开始的下标位置(必填)
endIndex:结束的下标位置(选填,如果没有,会从开始下标到最后元素的下标)

let arr =[1, 2, 3, 10, 21];
console.log(arr.slice(2)); // [3, 10, 21]
console.log(arr); //  [1, 2, 3, 10, 21]

concat()

返回组合后的新数组

let arr1 =[1, 2, 3];
let arr2 =[4, 5, 6];
console.log(arr1.concat(arr2)); //  [1, 2, 3, 4, 5, 6]

filter()

返回符合条件的新数组

let arr= [1, 2, 3, 4, 5];
let arr1 = arr.filter(item => item >= 3)
console.log(arr)    // [1, 2, 3, 4, 5]
console.log(arr1)  // [3, 4, 5]

map()

返回运算后的新数组

let arr= [1, 2, 3, 4]
let arr1 = arr.map(item => item+2)
console.log(arr)   //  [1, 2, 3, 4]
console.log(arr1)  //  [3, 4, 5, 6]

forEach()

遍历数组中的每个元素,可在遍历过程中给其他数组或者变量赋值

let arr= [1, 2, 3, 4]
let arr1 = [];
arr.forEach(item => arr1.push(item))
console.log(arr)   // [1, 2, 3, 4]
console.log(arr1)  // [1, 2, 3, 4]

find()

返回第一个符合条件的元素,如果都没有符合的则返回undefined

let arr= [1, 2, 3, 4];
let arr1= arr.find(item => item>2)
let arr2 = arr.find(item => item<1)
console.log(arr)   // [1, 2, 3, 4]
console.log(arr1)  // 3
console.log(arr2)  // undefined

findIndex()

返回第一个符合条件的元素的下标,如果没有则返回-1

let arr= [1, 2, 3, 4];
let arr1= arr.findIndex(item => item>2)
let arr2 = arr.findIndex(item => item<1)
console.log(arr)   // [1, 2, 3, 4]
console.log(arr1)  // 2
console.log(arr2)  // -1

some()

只要有一个元素满足条件,则表达式返回true

let arr= [1, 2, 3, 4];
let res= arr.some(item => item>2)
console.log(arr)   // [1, 2, 3, 4]
console.log(res)  // true

every()

只要有一个元素不满足,则整个表达式返回 false

let arr= [1, 2, 3, 4];
let res= arr.every(item => item>2)
console.log(arr)   // [1, 2, 3, 4]
console.log(res)  // false

其他方法

join(‘参数’)

将数组的元素以传入的参数为分割符,并转为字符串返回

let arr = [1,2,3,4,5];
let str = arr.join(',');
console.log(arr)
console.log(str)  // -> '1,2,3,4,5';

toString()

将数组的元素已逗号为分隔符,并转为字符串返回

let arr = [1,2,3,4,5,6];
console.log(arr.toString()) // -> '1,2,3,4,5,6'

indexOf()

查找对象数据是否存在于数组中,如果存在返回下标,如果不存在返回-1

let arr = [1,2,3,4];
console.log(arr.indexOf(1)) //  1
console.log(arr.indexOf(5)) // -1

reduce(callback,initial)

参数:
第一个是回调函数,表示在数组的每一项上调用的函数;
第二个参数(可选的)作为归并的初始值,被回调函数第一次执行时的第一个参数接收。

callback默认有四个参数,分别为prev,now,index,self。 callback返回的任何值都会作为下一次执行的第一个参数。 如果initial参数被省略,那么第一次迭代发生在数组的第二项上,因此callback的第一个参数是数组的第一项,第二个参数就是数组的第二项。

let arr = [1,2,3,4,5];
let sum = arr.reduce((prev,now) => prev+now)
console.log(sum); // 15;
let sum = arr.reduce((prev,now) => prev+now,1000)
console.log(sum) // 1015;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

vue 数组常用方法(总结) 的相关文章

随机推荐

  • keil5软件共用C51和ARM

    第一步 xff1a 创建文件夹keil mdk正常安装并破解MDK5 第二步 xff1a 创建另一个文件夹keil c51安装C51 将该文件夹里面的C51文件夹复制粘贴到keil mdk文件夹里与ARM文件夹保持同一目录 第三步 xff1
  • 【pytorch】Conv2d()里面的参数bias什么时候加,什么时候不加?

    代码中会发现有m 61 nn Conv2d 16 33 3 stride 61 2 bias 61 False bias是False xff0c 而默认的是True 因为一般为False的时候 xff0c nn Conv2d 后面通常接nn
  • Downloading https://ultralytics.com/assets/Arial.ttf to /data/..../.config/Ultralytics/Arial.ttf

    1 报错 xff1a 缺少字体Arial ttf 2 字体链接 xff1a https ultralytics com assets Arial ttf 3 方法 xff1a 下载该链接的字体 xff0c 然后放到 data config
  • 第四章 Opencv图像色彩空间与通道

    文章目录 1 色彩空间1 1 RGB BGR色彩空间1 2 GRAY色彩空间1 3 HSV色彩空间 2 通道2 1 拆分通道 xff1a 96 split 96 方法1 拆BGR色彩空间图像的通道2 拆HSV色彩空间图像的通道 2 2 合并
  • 第五章 Opencv图像的几何变换

    目录 1 缩放图像1 1 resize 方法 2 翻转图像2 1 flip 方法 3 仿射变换图像3 1 warpAffine 方法3 2 平移3 3 旋转3 4 倾斜 4 透视图像4 1 warpPerspective 方法 几何变换是指
  • pip、conda查看镜像源及更换镜像源

    1 查看已经安装过的镜像源 xff1a conda config show channels 查看配置项channels 2 删除镜像源 xff08 清华镜像源 xff09 xff1a conda config remove channel
  • 生成环境下的所有包

    pip freeze span class token operator gt span requirements span class token punctuation span txt 问题 xff1a 将虚拟环境的安装包导出 xff
  • java核心技术卷I

    第三章 xff1a java的基本程序设计结构 文章目录 第三章 xff1a java的基本程序设计结构3 2 注释3 3 数据类型3 4变量3 4 1初始化变量3 4 2常量 3 5运算符3 5 1数学函数与常量3 5 2数值类型之间的转
  • MOT学习笔记 — 行人检测及行人跟踪数据集总结

    1 行人红外数据集总结 xff08 1 xff09 OSU Thermal Pedestrian Database 下载链接 xff1a http vcipl okstate org pbvs bench Data 01 download
  • 使用k-近邻算法识别手写数字

    本文摘自 机器学习实战 案例 xff0c 对其进行了代码更新与注释 实战介绍 使用k 近邻分类器构造手写识别系统 xff0c 为了简单起见 xff0c 系统只识别0 9 xff0c 需要识别的数字已经使用图形处理软件 xff0c 处理成具有
  • ubuntu16.04下安装并使用小觅双目MYNT EYE 1.x SDK

    1 下载MYNT EYE 1 x SDK压缩包 首先 xff0c 点击进入github官网 xff0c 在右上角的搜索栏中输入mynt xff0c 进入如下界面 xff1a 点击第四个slightech MYNT EYE SDK进入 xff
  • UART通用异步收发传输器

    UART 全称Universal Asynchronous Receiver Transmitter xff0c 通用异步收发传输器 xff0c 是一种串行异步收发协议 又称为串口 xff09 功能是将并行的数据转变为串行的数据发送或者将接
  • C语言如何实现输入特定字符串(单词)作为终止符

    本文章以一个例题来进行讲解 xff08 新手第一次写 xff0c 目的仅是分享自己写代码中想到的一些方法和技巧 xff0c 仍存在很多不足 xff0c 希望能对大家有用 xff09 题目要求 xff1a 有一篇文章 xff0c 共有多行文字
  • kubernetes 教程 笔记

    K8s 安装kub ectl 下载kubectl curl LO 34 https dl k8s io release curl L s https dl k8s io release stable txt bin linux amd64
  • ros uwb2world坐标转换python示例

    ros uwb2world坐标转换python示例 span class token comment coding 61 utf 8 span span class token comment usr bin env python span
  • ARUCO marker的解释

    markers for ARUCO 一种汉明 海明 码的格子图 如图 百度百科解释汉明码规则概要 使用奇偶校验 具有一位纠错能力 校验位在2的次幂位置1 2 4 8 16 32 具体参看 https baike baidu com item
  • 使用ros_control ros_controllers 的牛刀真实驱动舵机手臂的源码

    现场 rqt graph 在一个陌生的框架下写代码 xff0c 免不了有很多疑问与槽点 不了解框架结构 xff0c 千头万续 xff0c 无从下手 xff0c 说不清 xff0c 理还乱 资料少没有文档 xff0c 要读懂程序猿的心 xff
  • 经典的pid公式,好脑子不如烂笔头。

    这个算法涉及昨天 xff0c 今天 xff0c 明天 思路就是以史为鉴 xff0c 预测明天 xff0c 改革当前
  • c++对8位灰度图进行二值化处理

    对灰度图进行位二值化 xff0c 输入图像像素部分的宽度和高度以及存储灰度像素值 得一维数组 xff0c 对灰度值进行直方图统计 xff0c 通过OSTU大律法公式 xff0c 确定自动灰度 图的阈值 xff0c 进而进行二值化处理 xff
  • vue 数组常用方法(总结)

    vue 数组常用方法 操作原数组push item pop shift unshift item n splice startIndex endIndex sort reverse 返回新数组slice startIndex endInde