JS

JS-数组操作

JS使用

Posted by 松下百合子 on July 1, 2019

JS当做笔记记之。

文章转载自博客园

数组末尾添加元素

  • push:将元素添加到原数组末尾,并返回数组的长度
1
2
var a = [1,2,3,4,5];   
var b = a.push(6,7); //a:[1,2,3,4,5,6,7] b:7   

数组开头添加元素

  • unshift:将参数添加到原数组开头,并返回数组的长度
1
2
var a = [1,2,3,4,5];   
var b = a.unshift(-2,-1); //a:[-2,-1,1,2,3,4,5] b:7   

注:在IE6.0下测试返回值总为undefined,FF2.0下测试返回值为7,所以这个方法的返回值不可靠,需要用返回值时可用splice代替本方法来使用。

删除数组第一项

  • shift: 删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined
1
2
var a = [1,2,3,4,5];   
var b = a.shift();  //a:[2,3,4,5]  b:1  

删除原数组最后一项

  • pop:删除原数组最后一项,并返回删除元素的值;如果数组为空则返回undefined
1
2
var a = [1,2,3,4,5];   
var b = a.pop();  //a:[1,2,3,4]  b:5  

连接创建一个新数组

  • concat:返回一个新数组,是将参数添加到原数组末尾中构成的
1
2
var a = [1,2,3,4,5];   
var b = a.concat(6,7); //a:[1,2,3,4,5] b:[1,2,3,4,5,6,7]  

对数组进行删除,添加,截取

  • splice(start,deleteCount,val1,val2,…):从start位置开始删除deleteCount项,并从该位置起插入val1,val2,…
1
2
3
4
5
6
var a = [1,2,3,4,5];   
var b = a.splice(2,2,7,8,9); //a:[1,2,7,8,9,5] b:[3,4]   
var b = a.splice(0,1); //shift   
a.splice(0,0,-2,-1); var b = a.length; //unshift   
var b = a.splice(a.length-1,1); //pop   
a.splice(a.length,0,6,7); var b = a.length; //push    

数组反序

  • reverse:将数组反序
1
2
var a = [1,2,3,4,5];   
var b = a.reverse(); //a:[5,4,3,2,1] b:[5,4,3,2,1]     

数组排序

  • sort(orderfunction):按指定的参数对数组进行排序
1
2
var a = [1,2,8,4,5];   
var b = a.sort(); //a:[1,2,4,5,8] b:[1,2,4,5,8]     

数组截取

  • slice(start,end):返回从原数组中指定开始下标到结束下标之间的项组成的新数组
1
2
var a = [1,2,3,4,5];   
var b = a.slice(2,5); //a:[1,2,3,4,5] b:[3,4,5]       

数组插入分隔符

  • join(separator):将数组的元素组起一个字符串,以separator为分隔符,省略的话则用默认用逗号为分隔符
1
2
var a = [1,2,3,4,5];   
var b = a.join("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5"      

数组过滤

  • filter方法
  • ①filter方法可以遍历数组
  • ②filter方法的参数是函数
  • ③filter方法函数有形参v
  • ④形参v指的是数组中每个元素
  • ⑤filter方法中函数有返回值(把符合条件的元素放在一个新数组中返回)
1
2
3
4
5
const arr = [1,2,3].filter((v)= > {
     console.log(v);  //输出为123
     return v>1;
})
console.log(arr);  //输出为[2,3];