JS——数组常用的方法

本文介绍了JavaScript中数组的一些常用操作方法,包括添加或删除元素、转换为字符串、翻转数组、冒泡排序、填充数组、替换、截取、遍历(map、forEach)、判断(every、some)以及高阶函数(filter、map、reduce)。详细讲解了这些方法的使用和特点,并特别指出它们是否改变原数组。
摘要由CSDN通过智能技术生成

1.添加或删除数组

方法名说明返回值
push(参数1,…)在原数组后面追加元素返回新数组的长度
pop()删除数组最后一个元素,数组长度-1,无参数返回删除的元素
unhshift(参数1,…)在原数组前面追加元素返回新数组的长度
shift()删除原数组的第一个元素,数组长度-1,无参数返回第一个元素
splice(索引号,个数)从索引号开始删除,删除几个返会删除的元素
splice(索引号,0,‘参数’)索引号后面添加参数返回空数组

规律: 增加元素一般返回新数组的长度,删除元素则返回删除的元素。而splice的增加是返回空数组。

// push()
var arr = [1,2,3];
console.log(arr.push('a','b')); //5 返回的是新数组长度
console.log(arr);               //[1,2,3,a,b]
// 同理unshift()
var arr = [1,2,3];
console.log(arr.unshift('a','b')); //5
console.log(arr);                  //[a,b,1,2,3]
// pop()
var arr = ['a','b','c'];
console.log(arr.pop()); //c 返回的是删除的元素 一次只能删一个
console.log(arr);       //[a,b]
// 同理shift()
var arr = ['a','b','c'];
console.log(arr.shift()); //a
console.log(arr);         //[b,c]
// splice()
var arr = ['a','b','c'];
console.log(arr.splice(1,1)); // b
console.log(arr);             // [a,c]

var arr = ['a','b','c'];
console.log(arr.splice(1,0,'d')) // []
console.log(arr);                // [a,b,d,c]

2.数组转换为字符串

方法名说明返回值
toString()逗号分隔每一项返回一个字符串
join(‘分隔符’)分隔符分隔每一项,若不加 ‘分隔符’ ,则默认为逗号,即与toString()一样返回一个字符串
var arr = [1, 2, 3];
console.log(arr.toString()) // 1,2,3  string
console.log(arr.join())     // 1,2,3  string
console.log(arr.join(''))   // 123    string
console.log(arr.join('-'))  // 1-2-3  string

3.翻转数组 reverse()

var arr = [1,2,3]
console.log(arr.reverse()) // [3,2,1]

4.冒泡排序 sort()

单独使用.sort()时,即没有参数。
判断个位数的大小,可以从小到大排序;
但是数值是多位数的时候,它的判断方式却变了,它先比较第一位数,再比较第二位…
所以下面案例中的排序是 1,13,4,7,77。

var arr1 = [1,4,7,3];
arr1.sort();
console.log(arr1); // [1,3,4,7]
var arr2 = [13,1,7,4,77];
arr2.sort();
console.log(arr2); //[1,13,4,7,77]

要想按照从小到大的排序,有以下模板:
arr.sort(function(a,b){
return a-b;//升序
});
从小到大:
arr.sort(function(a,b){
return b-a;//降序
});
注意:sort的括号是 括 整个函数的,最后记得加分号

var arr1 = [13,1,7,4,77];
arr1.sort(function(a,b){
	return a-b;//升序
});
console.log(arr1); //[1,4,7,13,77]
var arr2 = [13,1,7,4,77];
arr2.sort(function(a,b){
	return b-a;//降序
});
console.log(arr2); //[77,13,7,4,1]

5.填充数组 fill()

arr.fill() 是 ES6 的新方法。
fill() 方法用于将一个固定值替换数组的元素。

语法: array.fill(value, start, end)
参数

value 必需。填充的值。
start 可选。开始填充位置。
end 可选。停止填充位置 (默认为 array.length)
填充是从 start 位置开始,到 end-1 位置结束,不包含end位置.

let arr1 = [0, 1, 2, 3, 4, 5, 6, 7, 8];
arr1.fill(9, 2, 5);
console.log(arr1)  // [0, 1, 9, 9, 9, 5, 6, 7, 8]
let arr2 = [0, 1, 2, 3, 4, 5, 6, 7, 8];
arr2.fill(9);
console.log(arr2)  // [9, 9, 9, 9, 9, 9, 9, 9, 9]
let arr3 = [0, 1, 2, 3, 4, 5, 6, 7, 8];
arr3.fill(0, 4);
console.log(arr3)  // [0, 1, 2, 3, 9, 9, 9, 9, 9]

6.替换 copyWithin()

arr.fill() 是 ES6 的新方法。

let arr1 = [0, 1, 2, 3, 4]
arr1.copyWithin(0,2,3)
console.log(arr1)  // [2, 1, 2, 3, 4]
let arr2 = [0, 1, 2, 3, 4]
arr2.copyWithin(1,-2,-1)
console.log(arr2)  // [0, 3, 2, 3, 4]

7.截取数组 slice

slice(start, end) 返回截取的数组,原数组不改变
start: 必需。从start开始截取,负数表示倒数;
end: 可选。不包含end。默认为arr.length。负数表示倒数。

let arr1 = [0, 1, 2, 3, 4]
console.log(arr1.slice(0,2)) // [0, 1]
console.log(arr1)  // [0, 1, 2, 3, 4]

8.遍历数组 map、forEach

都不会改变原数组。
如何使用:当你遍历数组想要返回一个新的数组时使用map,如果你仅仅想遍历这个数组而不想返回一个新数组那么使用forEach。

map方法
1.map方法返回一个新的数组,数组中的元素为原始数组调用函数处理后的值。
2.map方法不会对空数组进行检测,map方法不会改变原始数组。

array.map(function(item,index,arr){},thisValue)
 
var arr = [0,2,4,6,8];
var newArr = arr.map(function(item,index,arr){
    console.log(this); //window
    console.log("原数组arr:",arr); // 注意这里执行5次[0,2,4,6,8]
    return item/2;
},this);
console.log(newArr);// [0,1,2,3,4]
console.log(arr) // [0,2,4,6,8]

forEach方法
1.forEach方法用来调用数组的每个元素,将元素传给回调函数
2.forEach对于空数组是不会调用回调函数的。
3.无论arr是不是空数组,forEach返回的都是undefined。 这个方法只是将数组中的每一项作为callback的参数执行一次。

Array.forEach(function(item,index,arr){},this)

var arr = [0,2,4,6,8];
var sum = 0;
var str = arr.forEach(function(item,index,arr){
    sum += item;
    console.log("sum的值为:",sum); // 5次:0 2 6 12 20
    console.log(this); //window
},this)
console.log(sum); // 20
console.log(str); // undefined
console.log(arr)  // [0,2,4,6,8]

10.判断 every()、some()

ES6新增的数组方法。
every:一假即假。必须所有都返回true才会返回true,哪怕只有一个false,就会返回false。
some:一真即真。只要其中一个为true 就会返回true的。
但是,有一点:如果every遇到一个false就不再往下走了,同理,some只要遇到一个true就不再往下走。

every、some跟函数:
arr.every(function(item, [index], [array] ){… return …})

let arr1 = [0, 1, 2, 3, 4]
let result = arr1.every(function(item) {
  console.log(item) // 0 1 不再往下走了
  return item < 1
})
console.log(result) // false
let arr1 = [0, 1, 2, 3, 4]
let result = arr1.some(function(item) {
  console.log(item)  // 0 1 2
  return item > 1
})
console.log(result)  // true

11.高阶函数 filter、map、reduce

JS——高阶函数.

是否会改变原数组

项目方法
改变原数组splice()、reverse()、fill()、copyWithin()、sort()、push()、pop()、unshift()、shift()
不会改变原数组slice()、map()、forEach()、every()、some()、filter()、reduce()、entries()、find()、concat()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值