数组的操作

简介: `splice`方法改变原数组,如`arr.splice(a, b)`从下标`a`开始截取`b`个数。`push()`在数组尾部添加元素并返回新长度,`pop()`删除并返回尾部元素。`unshift()`在头部添加,`shift()`删除并返回头部元素。`findIndex()`返回满足条件的元素下标,否则-1。`forEach`遍历数组,`map`类似但返回新数组。

1.splice

1.splice 是数组的一个方法,使用这个方法会改变原来的数组结构,splice(index ,howmany , itemX);这个方法接受三个参数,我们在使用的时候可根据自己的情况传递一个参数,或两个参数,或者三个参数;

2.使用的方法
==arr.splice(a,b)表示从下标为a数组截取b个数。==

    传递两个参数,第一个参数表示开始的位置,第二个参数表示要截取的个数;如果第二个参  数为0,则表示不截取,返回的空数组,原来的数组不变
    var arr = [2,4,6,7,8,9]; 
    console.log(arr);//[2,4,6,7,8,9]
    var n = arr.splice(2,3);//表示从下标位置为2开始截取3个数
    console.log(n);//[6, 7, 8]
    console.log(arr);//[2,4,9]

2.arr.push()返回的数组的长度
push()、pop()和unshift()、shift()
联系:这两组同为对数组的操作,并且会改变数组的本身的长度及内容。
区别:不同的是 push()、pop() 是从数组的尾部进行增减,unshift()、shift() 是从数组的头部进行增减。

==向数组的 尾部/头部 添加若干元素,并返回 数组的 新长度;==

  arr.push(3,4)//返回 arr 的新长度 4

  arr ;                        // arr = [1,2,3,4];

  arr.unshift(0,0.5);    // 返回 arr 的新长度 6

  arr ;                       // arr = [0,0.5,1,2,3,4];

==从数组的 尾部/头部 删除1个元素(删且只删除1个),并返回 被删除的元素;空数组是继续删除,不报错,但返回undefined==

  arr.pop();      //返回 4;
  
  arr ;          // arr = [0,0.5,1,2,3];
  
  arr.pop();      //返回 3;
  
     arr ;         // arr = [0,0.5,1,2];

  arr.shift();      // 返回 0 ;
  
  arr ;        // arr = [0.5,1,2]

2.findIndex

findIIndex()查找满足条件的下标,一旦条件满足则会返回对应添加的下标。
如果不满足条件则返回-1.

var arr = ['a','b','c','d'];
   var flag = arr.findIndex(item => {
   
   
        return item === 'c';
    })
    console.log(flag) // 得到: 2

对数组arr查找符合条件的值,发现在arr中对应数组下标为3的c满足条件则返回为3

3.Foreach和map

foreach方法主要是针对数组而言的,对数组中的每个元素可以执行一次方法
forearch(a,b,c) 其中
a对应的数组内容,b对应索引,c对应整个数组。

var array = ['a', 'b', 'c', 'e'];
array.forEach((a,b,c)=> {
   
   
  console.log(a);
  console.log(b);
  console.log(c);
});

image.png

map()的执行效果和foreach()差不多
只不过map的执行有返回值

var num = [1,2,3,4,5,6];
//把原数组的内容都乘以2,然后返回给一个新数组
var _num = num.map(item=>{
   
   
    return item *2
})
console.log(_num);        //[2, 4, 6, 8, 10, 12]
目录
相关文章
|
8月前
|
前端开发 Java
java前端:删除数组中指定元素的方法
java前端:删除数组中指定元素的方法
116 1
|
7月前
|
索引
删除数组中的指定元素(了解如何删除数组中的指定元素,并返回一个新的数组,看这一篇就足够了!)
删除数组中的指定元素(了解如何删除数组中的指定元素,并返回一个新的数组,看这一篇就足够了!)
|
7月前
|
编译器
数组\插入删除数组元素
数组\插入删除数组元素
29 0
|
8月前
如何删除数组中的某个元素?
如何删除数组中的某个元素?
82 0
|
8月前
|
存储 Scala
创建集合和数组
创建集合和数组
53 0
|
8月前
|
存储 Java
数据结构:图文详解顺序表的各种操作(新增元素,查找元素,删除元素,给指定位置元素赋值)
数据结构:图文详解顺序表的各种操作(新增元素,查找元素,删除元素,给指定位置元素赋值)
291 0
曲线救国 —— 删除数组的指定元素
曲线救国 —— 删除数组的指定元素
40 0
|
JSON C# 数据格式
数组比较的几种方式
1、string.Equals() ```csharp string[] strList1= new string[3] {"1", "2", "3"}; string[] strList2= new string[3] {"4", "5", "6"}; if (!string.Equals(strList1, strList2)) { // 比较数组的不同之处 } // 涉及到修改日志输出等数组可以直接json序列化然后用上述方法比较即可,如下 if (!string.Equals(JsonConvert.SerializeObject(list1), JsonConvert
88 0
|
存储 编译器 C++
【C++要笑着学】vector 常用接口介绍 | 遍历操作 | 空间操作 | 增删查改(一)
本章开始讲解 vector,首先对 vector 进行介绍,然后讲解 vector 常用的接口。像 emplace 等涉及右值引用的接口,我们等后期讲C++11的时候再作讲解。话不多说,直接开讲。
276 1
【C++要笑着学】vector 常用接口介绍 | 遍历操作 | 空间操作 | 增删查改(一)
|
存储 算法 C++
【C++要笑着学】vector 常用接口介绍 | 遍历操作 | 空间操作 | 增删查改(二)
本章开始讲解 vector,首先对 vector 进行介绍,然后讲解 vector 常用的接口。像 emplace 等涉及右值引用的接口,我们等后期讲C++11的时候再作讲解。话不多说,直接开讲。
154 0
【C++要笑着学】vector 常用接口介绍 | 遍历操作 | 空间操作 | 增删查改(二)