js 数组相关操作

2018-10-24  本文已影响0人  direwolf_
插入
var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.unshift(8));  //9
console.log(arr);  //[8, 0, 1, 2, 3, 4, 5, 6, 7]
var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.push(8));  //9
console.log(arr);  //[0, 1, 2, 3, 4, 5, 6, 7, 8]

移除

var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.shift());  //0
console.log(arr);  //[1, 2, 3, 4, 5, 6, 7]
var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.pop());  //7
console.log(arr);  //[0, 1, 2, 3, 4, 5, 6]

合并

var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.concat(8, 9, 10));  //[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
console.log(arr);  //[0, 1, 2, 3, 4, 5, 6, 7]

搜索

var arr = [1, 3, 5, 2, 6, 4, 10, 8];
console.log(arr.indexOf(2)); //3
console.log(arr); //[1, 3, 5, 2, 6, 4, 10, 8]

截取

arr.slice(start, end); start 起始位置(截取位置并包含)end 结束位置(截取位置并不包含)

var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.slice(1, 5));  //[1, 2, 3, 4]
console.log(arr);  //[0, 1, 2, 3, 4, 5, 6, 7]

arr.splice(start, n, index, index1, ..., indexx) start 是起始位置,n 是删除元素的个数,index 是要添加的元素,如果不需要添加元素,第一个参数必填,后面两个选填;如果需要添加元素,三个元素都是必填。

var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.splice(1, 5)); //[1, 2, 3, 4, 5]
console.log(arr); //[0, 6, 7]

var arr = [0, 1, 2, 3, 4, 5, 6, 7];
console.log(arr.splice(1, 5, 'add')); //[1, 2, 3, 4, 5]
console.log(arr); //[0, "add", 6, 7]

排序

var arr = [1, 3, 5, 2, 6, 4, 10, 8];
console.log(arr.sort(function (a, b) {
  return a - b
}));    //[1, 2, 3, 4, 5, 6, 8, 10]
console.log(arr); //[1, 2, 3, 4, 5, 6, 8, 10]
var arr = [1, 3, 5, 2, 6, 4, 10, 8];
console.log(arr.sort(function (a, b) {
  return b - a
})); //[10, 8, 6, 5, 4, 3, 2, 1]
  console.log(arr); //[10, 8, 6, 5, 4, 3, 2, 1]

倒序

var arr = [1, 2, 3, 4, 5, 6, 7];
console.log(arr.reverse()); //[7, 6, 5, 4, 3, 2, 1]
console.log(arr); //[7, 6, 5, 4, 3, 2, 1]

转换字符串

var arr = [1, 2, 3, 4, 5, 6, 7];
console.log(arr.join()); //1,2,3,4,5,6,7
console.log(arr.join('-')); //1-2-3-4-5-6-7
console.log(arr); //[1, 2, 3, 4, 5, 6, 7]

筛选符合条件项

array.filter(function(currentValue, index, arr), thisValue);

  1. function(currentValue, index, arr): 回调函数,必填,用来制定检索规则;
    a. currentValue: 必选,当前元素
    b. index: 可选,当前元素索引值
    c. arr: 可选,当前元素所属的数组对象
  2. thisValue: 可选,用来指定回调函数中 this 所指向的对象
let arr = [1, 2, 3, 4, 5, 6];
let obj = {
    num: 3
}
let arrFilter = arr.filter(function(v, i, arr) {
    console.log(this); //{num: 3}
    console.log(v); //1 ~ 6
    console.log(i); //0 ~ 5
    console.log(arr); //[1, 2, 3, 4, 5, 6]
    return v > this.num;
}, obj); //[4, 5, 6]

查找符合条件项

array.find(function(currentValue, index, arr), thisValue)

  1. function(currentValue, index, arr): 回调函数,必填,用来制定检索规则;
    a. currentValue: 必选,当前元素
    b. index: 可选,当前元素索引值
    c. arr: 可选,当前元素所属的数组对象
  2. thisValue: 可选,用来指定回调函数中 this 所指向的对象
let arr = [1, 2, 3, 4, 5, 6];
let obj = {
    num: 3
}
let arrFind = arr.find(function(v, i, arr) {
    console.log(this); //{num: 3}
    console.log(v); //1 ~ 4 —— 因为发现满足条件项后便会终止 find() 方法,所以是1 ~ 4
    console.log(i); //0 ~ 3 —— 因为发现满足条件项后便会终止 find() 方法,所以是0 ~ 3
    console.log(arr); //[1, 2, 3, 4, 5, 6]
    return v > this.num;
}, obj); //4

数组处理

let arr = [1, 2, 3, 4, 5, 6];
let obj = {
    num: 3
}
let arrFilter = arr.map(function(v, i, arr) {
    console.log(this); //{num: 3}
    console.log(v); //1 ~ 6
    console.log(i); //0 ~ 5
    console.log(arr); //[1, 2, 3, 4, 5, 6]
    return v + this.num;
}, obj); //[4, 5, 6, 7, 8, 9]

数组遍历

let arr = [1, 2, 3, 4, 5, 6];
let obj = {
    num: 3
}
arr.forEach(function(v, i, arr) {
    console.log(v); //1 ~ 6
    console.log(i); //0 ~ 5
    console.log(arr); //[1, 2, 3, 4, 5, 6]
    this.num += v;
}, obj);
console.log(obj); //{num: 24}
上一篇 下一篇

猜你喜欢

热点阅读