Js数组常用方法

//JS数组常用方法及其应用

/**

* 1.push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。

* pop(): 删除数组的最后一个元素,并返回该元素。注意,该方法会改变原数组。

*/

let arr1 = ["a","b","c"];

console.log("arr1:" + arr1);

arr1.push("d");

console.log("arr1:" + arr1);

let t = arr1.pop();

console.log("arr1.pop():" + t);

console.log("arr1:" + arr1);

输出:

arr1:a,b,c

arr1:a,b,c,d

arr1.pop():d

arr1:a,b,c

/**

* 2.unshift():在数组的第一个位置添加元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。

* shift():删除数组的第一个元素,并返回该元素。注意,该方法会改变原数组。

*/

let arr1 = ["a","b","c"];

console.log("arr1:" + arr1);

arr1.unshift("d");

console.log("arr1:" + arr1);

arr1.shift();

console.log("arr1:" + arr1);

输出:

arr1:a,b,c

arr1:d,a,b,c

arr1:a,b,c

利用shift和pop方法可以分别正序逆序输出数组值,但是遍历之后原数组中的数据被清空了:

let elem;

while (elem = arr1.shift()) {

    console.log(elem);

}

while (elem = arr1.pop()) {

    console.log(elem);

}

/**

* 3.indexOf():返回指定元素在数组中出现的位置,如果没有出现则返回-1。indexOf方法还可以接受第二个参数,表示搜索的开始位置。

*/

let arr1 = ["a","b","c"];

console.log("arr1:" + arr1.indexOf("a"));

console.log("arr1:" + arr1.indexOf("d"));

console.log("arr1:" + arr1.indexOf("a",1));

输出:

arr1:0

arr1:-1

arr1:-1

利用indexof可以遍历数组,做数值的比较操作:

function topicsCompare( topics1, topics2, cb ){

    let add = [];

    let remove = [];

    for (let key in topics1) {

        let top1 = topics1[key];

        // console.log("top1"+top1);

        if( topics2.indexOf(top1) === (-1) ){

            //输出topics1中存在,topics2中不存在的数据

            console.log("---"+top1);

            remove.push(top1);

        }

    }

    for (let key in topics2) {

        let top2 = topics2[key];

        // console.log("top2"+top2);

        if( topics1.indexOf(top2) === (-1) ){

             //输出topics2中存在,topics1中不存在的数据

            console.log("+++"+top2);

            add.push(top2);

        }

    }

    return cb(add,remove);

}

/**

* 4.join():以参数作为分隔符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分隔。

*/

let arr1 = ["a","b","c"];

console.log("arr1:" + arr1);

console.log("arr1:" + arr1.join());

console.log("arr1:" + arr1.join(" "));

console.log("arr1:" + arr1.join("|"));

console.log("arr1:" + arr1.join("*"));

输出:

arr1:a,b,c

arr1:a,b,c

arr1:a b c

arr1:a|b|c

arr1:a*b*c

/**

* 5.concat():用于多个数组的合并。它将新数组的成员,添加到原数组的尾部,然后返回一个新数组,原数组不变。

*/

let arr1 = ["a","b","c"];

let arr2 = ["d","e"];

console.log("arr1:" + arr1);

console.log("arr1:" + arr1.concat(arr2));

输出:

arr1:a,b,c

arr1:a,b,c,d,e

/**

* 6.reverse():用于颠倒数组中元素的顺序,返回改变后的数组。注意,该方法将改变原数组。

*/

let arr1 = ["a","b","c"];

console.log("arr1:" + arr1);

console.log("arr1:" + arr1.reverse());

输出:

arr1:a,b,c

arr1:c,b,a

/**

* 7.slice():用于截取原数组的一部分,返回一个新数组,原数组不变。

* slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。

*/

let arr = ['a', 'b', 'c'];

console.log("arr1:" + arr.slice(0));        // ["a", "b", "c"]

console.log("arr1:" + arr.slice(1));        // ["b", "c"]

console.log("arr1:" + arr.slice(1, 2));    // ["b"]

console.log("arr1:" + arr.slice(2, 6));    // ["c"]

console.log("arr1:" + arr.slice());          // ["a", "b", "c"]    无参数返回原数组

console.log("arr1:" + arr.slice(-2));          // ["b", "c"]    参数是负数,则表示倒数计算的位置

console.log("arr1:" + arr.slice(-2, -1));    // ["b"]

输出:

arr1:a,b,c

arr1:b,c

arr1:b

arr1:c

arr1:a,b,c

arr1:b,c

arr1:b

/**

* 8.splice():删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组。

* splice(start,delNum,addElement1,addElement2,...)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。

*/

let arr1 = ["a","b","c","d","e","f"];

let arr2 = ["1","2","3"];

console.log("arr1:" + arr1);

console.log("arr1:" + arr1.splice(4, 2));

console.log("arr1:" + arr1);

console.log("arr1:" + arr1.splice(4, 2, arr2));

console.log("arr1:"+ arr1);

console.log("arr1:" + arr1.splice(-4, 2));//起始位置如果是负数,就表示从倒数位置开始删除

console.log("arr1:"+ arr1);

console.log("arr1:" + arr1.splice(2, 0, "c", "d", "e", "f"));//如果只插入元素,第二个参数可以设为0,此处表示从第二个位置后面开始插入

console.log("arr1:"+ arr1);

console.log("arr1:" + arr1.splice(4));//如果只有第一个参数,等同于将原数组在指定位置拆分成两个数组

console.log("arr1:"+ arr1);//此处表示从第4个位置开始

输出:

arr1:a,b,c,d,e,f

arr1:e,f

arr1:a,b,c,d

arr1:

arr1:a,b,c,d,1,2,3

arr1:b,c

arr1:a,d,1,2,3

arr1:

arr1:a,d,c,d,e,f,1,2,3

arr1:e,f,1,2,3

arr1:a,d,c,d

/**

* 9.sort():对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变。

* sort方法不是按照大小排序,而是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进行比较,所以101排在11的前面。

*/

let arr1 = ["a","b","e","f","c","d"];

let arr2 = [1,2,9,3,4,5];

let arr3 = [111, 1101, 10111];

console.log("arr1:" + arr1.sort());

console.log("arr1:" + arr2.sort());

console.log("arr1:" + arr3.sort());

输出:

arr1:a,b,c,d,e,f

arr1:1,2,3,4,5,9

arr1:10111,1101,111

如果想让sort方法按照自定义方式排序,可以传入一个函数作为参数,表示按照自定义方法进行排序。该函数本身又接受两个参数,表示进行比较的两个元素。

如果返回值大于0,表示第一个元素排在第二个元素后面;其他情况下,都是第一个元素排在第二个元素前面。

let arr1 = [10111, 1101, 111];

let arr2 = [

    { name: "张三", age: 30 },

    { name: "李四", age: 24 },

    { name: "王五", age: 28 }

]

arr1.sort(function (a, b) {

  return a - b;

})

arr2.sort(function (o1, o2) {

  return o1.age - o2.age;

})

console.log("arr1:" + arr1);

console.log(arr2);

输出:

arr1:111,1101,10111

[ { name: '李四', age: 24 },

  { name: '王五', age: 28 },

  { name: '张三', age: 30 } ]

/**

* 10.map():对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组。

*/

let arr1 = [1, 2, 3];

let arr2 = arr1.map(function (n) {

  return n + "s";

});

console.log("arr1:" + arr1);

console.log("arr1:" + arr2);

输出:

arr1:1,2,3

arr1:1s,2s,3s

/**

* 11.filter():参数是一个函数,所有数组成员依次执行该函数,返回结果为true的成员组成一个新数组返回。该方法不会改变原数组。

*对比filter与map的输出区别

*/

let arr1 = [1, 2, 3, 4, 5];

let arr2 = arr1.map(function (n) {

  return n>2;

});

let arr3 = arr1.filter(function (n){

    return n>2;

});

console.log("arr1:" + arr1);

console.log("arr1:" + arr2);

console.log("arr1:" + arr3);

输出:

arr1:1,2,3,4,5

arr1:false,false,true,true,true

arr1:3,4,5

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

推荐阅读更多精彩内容

  • 1、新的声明方式 以前我们在声明时只有一种方法,就是使用var来进行声明,ES6对声明的进行了扩展,现在可以有三种...
    令武阅读 976评论 0 7
  • 由于最近都在freecodecamp上刷代码,运用了很多JavaScript数组的方法,因此做了一份关于JavaS...
    2bc5f46e925b阅读 1,951评论 0 16
  • 添加(返回新的数组长度) 末尾添加 arr.push(els) 开头添加 arr.unshift(els) 删除(...
    追卓2018阅读 415评论 0 0
  • 1、使用typeof bar ===“object”来确定bar是否是一个对象时有什么潜在的缺陷?这个陷阱如何避免...
    深海鲫鱼堡阅读 654评论 1 1
  • 如果一时半会不知道做什么项目, 可以发现身边热的项目, 或者一些可以给你灵感的项目! 尝试问自己,如果让你做,你能...
    乌龟的慢生活阅读 251评论 0 0