数组常用方法及作用

目录

一、前言【什么是数组?】

数组,是有序的元素序列,用于储存多个相同类型数据的集合,数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按无序的形式组织起来的一种形式。这些无序排列的同类数据元素的集合称为数组。

二、数组常用的方法

1. length属性,可以用来获取数组的长度

var arr = [1,2,3,4,5,6,7,7]
console.log(arr.length)     //长度为8
arr.length = 4;            //可以使用数组的length属性来实现删除操作,4表示长度是4
console.log(arr)    //[1,2,3,4]

var arr = [1,2,3,4,5,6,7,7]
arr[arr.length] = 8     //新增  
console.log(arr)     // [1, 2, 3, 4, 5, 6, 7, 7, 8]

arr[5] = 10        //替换
console.log(arr)      //[1, 2, 3, 4, 5, 10, 7, 7, 8]

2. 新增和删除

push():向数组的尾部新增一个或者多个元素
var arr = [1,2,3,4,5,6,7,7]
arr.push(10)
arr.push(11,12)
console.log(arr)    //[1, 2, 3, 4, 5, 6, 7, 7, 10, 11, 12]
 var obj = {
             username:'张三',
             age:30
           }

//数组中可以放任意的数组类型
var arr  = [];
arr.push(obj)
arr.push(1,true,'zhangsan')
console.log(arr)        //[{username: '张三', age: 30}, 1, true, 'zhangsan']
unshift():向数组的头部新增一个或者多个元素
var arr = [1,2,3,4,5,6,7,7]
arr.unshift(10)
console.log(arr)    // [10, 1, 2, 3, 4, 5, 6, 7, 7]
pop():从数组的尾部删除元素
var arr = [1,2,3,4,5,6,7,7]
arr.pop()
console.log(arr)    // [1, 2, 3, 4, 5, 6, 7]
shift():从数组的头部删除元素
var arr = [1,2,3,4,5,6,7,7]
arr.shift()
console.log(arr)    // [2, 3, 4, 5, 6, 7, 7]

3. splice()的用法

splice(index,0,val,val2…):从数组的index下标开始新增N个元素
var arr = [1,2,3,4,5,6]
arr.splice(3,0,7,8,9)
console.log(arr)    //[1, 2, 3, 7, 8, 9, 4, 5, 6]
splice(index,num):从数组的index下标开始删除num个元素,删除完后会返回删除的元素组成的新数组
var arr = [1,2,3,4,5,7]
var arr2 = arr.splice(3,1)
console.log(arr2)    //[4]
console.log(arr)     //[1, 2, 3, 5, 7]
splice(index,num,val,val1…):从数组的index下标开始删除num个元素并且新增N个元素。
var arr = [1,2,3,4,5,6,7,7]
var arr2 = arr.splice(3,2,10,11,12)
console.log(arr2) //[4,5]
console.log(arr) //[1, 2, 3, 10, 11, 12, 6, 7, 7]

4. delete运算符也可以用来删除,但不会更改数组的长度。

var arr = [1,2,3,4,5,6,7,7]
delete arr[3]
console.log(arr)   //[1, 2, 3, 空白, 5, 6, 7, 7]

5. 数组元素位置的查找:

indefOf():从前向后查找,存在则返回元素下标,不存在返回-1;
lastIndefOf():从后向前查找,存在则返回元素的下标,不存在则返回-1;
includes():判断元素是否存在,存在返回true,不存在则返回-1;
var arr = [1,2,3,4,5,6,7,7]
console.log(arr.indexOf(7))       //下标是6
console.log(arr.lastIndexOf(5))   //下标是4
console.log(arr.includes(8))  //false
console.log(arr.includes(7))  //true

6. 排序

reverse():倒序
var arr = [1,2,3,4,5,6]

console,log(arr.reverse())     //  [6, 4, 3, 2, 1]
sort():不传值的情况下,按照ASCLL值排序
var arr = [1,11,2,12,3,23,4,25]
console.log(arr.sort())   //[1, 11, 12, 2, 23, 25, 3, 4]
sort():升序

格式:

​ 数组. sort(function(a,b){

​ return a-b;

​ })

var arr = [1,8,5,6,11,7,55,20,36,4]
console.log(arr.sort(function(a,b){
	return a-b
}))     //[1, 4, 5, 6, 7, 8, 11, 20, 36, 55]
sort():降序

格式:

​ 数组. sort(function(a,b){

​ return b-a;

​ })

var arr = [1,11,2,12,3,23,4,25]
console.log(arr.sort(function(a,b){
	return b-a
}))  //[25, 23, 12, 11, 4, 3, 2, 1]

7. concat():合并数组

var arr = [1,2,4,5,8,3,44,22,47]
var arr1 = [1,2,3];
var arr2 = [4,5,6];
console.log(arr.concat(arr1,arr2))   //[1, 2, 4, 5, 8, 3, 44, 22, 47, 1, 2, 3, 4, 5, 6]

8. join():将数组转换为字符串

var arr = [1,2,4,5,8,3,44,22,47]
console.log(arr.join())   //1,2,4,5,8,3,44,22,47

9. slice():数组截取,不会对原数组做影响

slice():不传值的情况下截取整个数组
var arr = [1,2,4,5,8,3,44,22,47]
var arr2 = arr.slice(2)
console.log(arr2)   //[4, 5, 8, 3, 44, 22, 47]
slice(start,end):从start位置开始截取到end,不包括end位置
var arr = [1,2,4,5,8,3,44,22,47]
var arr2 = arr.slice(2,5)
console.log(arr2)    //[4, 5, 8]
slice():可以传负值
var arr = [1,2,4,5,8,3,44,22,47]
var arr2 = arr.slice(-2)
console.log(arr2)        //[22, 47]

10. 循环方法

forEach()循环

​ forEach()方法用于调用数组的每个元素,并将元素传递给回调函数

​ 注意:forEach()对于空数组是不会执行回调函数的。

格式:

​ /**

​ *item:值

​ *index:下标

​ */

​ 数组.forEach(function(item,index){

​ })

例子:

var arr = [1,2,22,333,4,5,66,6,6,5,4,3,2,1]
arr.forEach(function(item,index){
	console.log('值为'+item+'下标='+index)
})
some():需要数组一项满足条件则返回true,只要有一项是满足的就返回true

格式:

​ 数组.some(function(item){

​ return 条件

​ })

例子:

var arr = [1,2,3,4,5,6,7,7,1,2,3,44,22,5,11]
var istrue = arr.some(function(x){
	return x > 5
})
console.log(istrue)   //true
every():需要数组每一项都满足条件则返回true

格式:

​ 数组.some(function(item){

​ return 条件

​ })

例子:

var arr = [1,2,3,4,5,6,7,7,1,2,3,44,22,5,11]
var istrue = arr.every(function(x){
	return x>=1
})
console.log(istrue)   //true
filter():返回满足条件的元素组成新的数组

格式:

​ 数组.some(function(item){

​ return 条件

​ })

例子:

 var arr = [1,2,3,4,5,6,7,7,1,2,3,44,22,5,11]
 var arr2 = arr.filter(function(x){
 	return x>5
 })
 console.log(arr2)  //[6, 7, 7, 44, 22, 11]
map():返回计算后的元素组成新数组

格式:

​ 数组.some(function(item){

​ return 条件

​ })

例子:

var arr = [1,2,3,4,5,6,7,7,1,2,3]
var arr2 = arr.map(function(x){
	return x*x
})
console.log(arr2)  //[1, 4, 9, 16, 25, 36, 49, 49, 1, 4, 9]

在这里插入图片描述

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏兮颜☆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值