js 数组相关操作

插入
  • unshift: 向数组的开头插入元素,并返回新的数组长度
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]
  • push: 向数组的结尾插入元素,并返回新的数组长度
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]

移除

  • shift: 删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined
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]
  • pop: 删除原数组最后一项,并返回删除元素的值;如果数组为空则返回undefined
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]

合并

  • concat: 返回一个将元素合并后的新数组,原数组保持不变
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]

搜索

  • indexOf: 返回元素索引,不存在返回-1,索引从0开始
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]

截取

  • slice: 返回从原数组中指定开始索引(包含)到结束索引(不包含)之间的元素组成的新数组,原数组保持不变,索引从0开始

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]
  • splice: 返回剪接的元素数组,原数组发生改变 ,索引从0开始

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]

排序

  • sort: 对数组进行排序;a - b 为正序;b - a 为倒序
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]

倒序

  • reverse: 返回倒序后的原数组,原数组同样进行倒序了
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]

转换字符串

  • join: 返回数组元素组起的一个字符串,原数组保持不变(省略的话则用默认用逗号为分隔符 )
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]

筛选符合条件项

  • filter: 创建一个新的数组,新数组中的元素是指定数组中符合条件的所有元素(空数组会报错)

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]

查找符合条件项

  • find: 返回通过测试的数组的第一个元素的值(空数组会报错,没有符合条件的元素返回 undefined)

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

数组处理

  • map(): 返回一个由原始数组元素调用函数处理后组成的新数组
    array.map(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.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]

数组遍历

  • forEach(): 返回一个由原始数组元素调用函数处理后组成的新数组()
    array.forEach(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
}
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}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容