数组中常用方法的总结

数组中常用方法

  1. push()
  2. pop()
  3. shift()
  4. unshift()
  5. splice()
  6. slice()
  7. join()
  8. concat()
  9. sort()
  10. reverse()

其中不会修改原数组并返回一个新的数组或者字符串的有

  1. slice()
  2. join()
  3. concat()

给数组的尾部添加或者删除元素

  1. push(element1, ..., elementN) 给数组尾部添加一个或者多个元素,返回数组新的长度(length属性值)
arr.push(element1, ..., elementN)
参数:elementN   被添加数组尾部的元素。
返回值:  当调用该方法时,新的 length 属性值将被返回。
  1. pop()方法删除数组最后一个元素,并返回被删除的元素。
arr.pop()

代码演示

var a=[1,2,3,4,5]
var b=a.push(6,7)
console.log(b)  //7
console.log(a)  //[1, 2, 3, 4, 5, 6, 7]
var c=['a','b','c','d']
var d=c.pop();
console.log(d)   //'d'
console.log(c)   //["a", "b", "c"]

给数组开头添加和删除元素

  1. unshift()方法给数组的开头添加一个或者多个元素,返回数组新的length值。
arr.unshift(element1, ..., elementN)
参数:elementN    被添加到数组的开头。
返回值:   当调用该方法的时,返回其length属性值。
  1. shift()方法删除数组的第一个元素,并返回这个元素。该方法是改变当前数组,所以会改变数组的长度
arr.shift()

描述:
shift() 方法移除索引为 0 的元素(即第一个元素),并返回被移除的元素,其他元素的索引值随之减 1。如果 length属性的值为 0 (长度为 0),则返回 undefined 。

代码演示

var a=[1,2,3,4]
var c=[1,2,3,4]
var b= a.unshift(5,6)  //b=6
var d=c.shift()  // d=1
a  // [5, 6, 1, 2, 3, 4]
c  // [2, 3, 4]

获取数组的片段的2个方法

splice()和slice()都可以获取数组的片段,但是2个方法有很大的区别
splice()和slice()的区别
  1. splice()会改变原数组。而slice()不会改变原数组,返回一个新的数组。
  2. splice()方法用新元素替换旧元素,以此来修改数组内容。而slice()方法会浅复制数组的一部分到一个新的数组,并返回这个新数组。

splice()方法

arr.splice(start,deleteCount,item1 .....itemN)
返回值: 由被删除的元素组成的一个数组。如果只删除了一个元素,则返回只包含一个元素的数组。如果没有删除元素,则返回空数组。
  1. start:从数组的哪一个索引来开始修改内容,如果超过数组长度,则从数组末尾开始添加内容,如果是负值,则从数组的末尾开始的第几位。
  2. deleteCount:整数,表示删除的个数。如果deleteCount是0,则不删除元素。这种情况下,一般都是添加新元素,不然就没有实际意义。(** 从start开始,包括start **)
  3. item1 .....itemN要添加的元素,如果不指定,splice()则只删除元素。(会在start前面添加元素)

splice()代码事例

    var a=['a','b','c','d'];
    var b= a.splice(0,2,1,2);  //b=[a,b]  a=[1,2,c,d]
    //给a开头添加一个元素
    var c =a.splice(0,0,'start','add'); //c=[]  a=["start", "add", 1, 2, "c", "d"]

用splice()方法变相的模拟push(),pop(),shift(),unshift()

    //splice()方法模仿push()*/
    function push(arr,val){
        arr.splice(arr.length,0,val);
        return arr.length
    }
    //splice()方法模仿pop()
    function pop(arr){
        return arr.splice(arr.length-1,1)[0]
    }
    //splice()方法模仿unshift()
    function unshift(arr,val){
        arr.splice(0,0,val);
        return arr.length;
    }
    //splice()方法模拟shift()
    function shift(){
        return arr.splice(0,1)[0]
    }

slice()方法

slice()方法提取元素,返回一个又提取元素组成的新数组

arr.slice(start,end);

参数
start : 从该索引开始提取元素(索引是从0开始)。如果start是负数,则从最后倒数几个来提取元素。如果省略begin,则slice()从0开始。
end : slice()方法截取元素的停止位置。如果为负数,则从倒数第几个元素结束。
返回值 : 一个含有提取元素的新数组。
新数组的长度等于(end- start) ,截取从start开始,end结束,但是不包括end

slice(-2,-1)表示从原数组的倒数第二个元素开始截取,到最后一个前停止
(不包含最后一个元素,也就是说只有倒数第二个元素)

slice()代码事例

    var hh=[1,2,3,4]
    var cc=hh.slice(0, 2)  //cc=[1, 2] 
    console.log(hh);  //hh=[1,2,3,4]

join()方法

join()把数组中所有元素连接成字符串。不会改变原数组的内容,返回的新的字符串。

arr.join(separator)

separator: 可选,用于指定连接每个数组元素的分隔符。分隔符会被转成字符串类型;如果省略的话,默认为一个逗号。如果 seprator 是一个空字符串,那么数组中的所有元素将被直接连接。

join()代码事例

    var a=[1,2,3,4];
    var b=a.join(); //b='1,2,3,4'
    var c=a.join("") //c='1234'
    var d=a.join("+") //d = "1+2+3+4"

concat()方法

concat()方法连接2个数组,返回一个新的数组,不改变原来的数组

    var aa=[1,2,3,4];
    var bb=['a','b','c','d'];
    var cc=aa.concat(bb)  //cc  = [1, 2, 3, 4, "a", "b", "c", "d"]
    var dd=aa.concat(5,6,7) //dd =[1, 2, 3, 4, 5, 6, 7]

reverse()方法

reverse()方法反序数组的内容,第一个元素会成为最后一个,最后一个会成为第一个。(是改变的原数组
返回值 : 返回改变后的数组

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

sort()方法

sort()方法对数组的做原地的排序,并返回这个数组。(是改变的原数组
返回值 : 返回改变后的数组

arr.sort(compareFunction)

compareFunction : 可选,按照某种顺序进行排列的函数。如果省略,元素按照Unicode进行排序

sort()方法代码事例

  1. 无参数
var a=[1,10,2,21] 
a.sort()  //  [1, 10, 2, 21]
// a=[1, 10, 2, 21] 
所以sort有时候会不准
  1. 添加函数进行比较

指明了 compareFunction ,那么数组会按照调用该函数的返回值排序。记 a 和 b 是两个将要被比较的元素:

  • 如果 compareFunction(a, b) 小于 0 ,那么 a 会被排列到 b 之前;
  • 如果 compareFunction(a, b) 等于 0 , a 和 b 的相对位置不变。
  • 如果 compareFunction(a, b) 大于 0 , b 会被排列到 a 之前。
数字的排序比较
function(a,b){
      return a-b;
}
eg:
var a=[3,5,7,45,36,1,18]
a.sort(function(a,b){
      return a-b;
})  //[1, 3, 5, 7, 18, 36, 45]
// a=[1, 3, 5, 7, 18, 36, 45]
对象属性的比较
function(a,b){
    if(a.value>b.value)  return  1;
    else if (a.value<b.value) return -1;
    else return 0
}
    var items = [
      { name: 'Edward', value: 21 },
      { name: 'Sharpe', value: 37 },
      { name: 'And', value: 45 },
      { name: 'Ahe', value: -12 },
      { name: 'Magnetic' },
      { name: 'Zeros', value: 37 }
    ];
items.sort(function(a,b){
     if(a.value>b.value)  return  1;
    else if (a.value<b.value) return -1;
    else return 0
})
此时items会按照value的大小排列
我们获取items[i].value  看看
    var arr=[]
    for(var i=0 ;i<items.length ;i++){
        arr[i]= items[i].value;
    }
      // arr=[-12, 10, 21, 37, 37, 45]
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容

  • Javascript有很多数组的方法,有的人有W3C的API,还可以去MDN上去找,但是我觉得API上说的不全,M...
    顽皮的雪狐七七阅读 4,075评论 0 6
  • 检测数组 利用instanceof(实例) 关键字语法: arr instanceof Array 返回值...
    尹林阳阅读 468评论 1 5
  • 数组的定义 数组是按序号排列的一组值,每个值的位置都有编号(从0开始)。数组本质上是一种特殊的对象。它的键名是按(...
    Allin_Lin阅读 551评论 0 0
  • 你看,叶子上留有昨晚倾泻的月光。 今日白露。 汉语中,仅“白露”二字,就是一首诗。 白露,有“蒹葭苍苍,白露为霜。...
    月令釆奇阅读 818评论 0 5
  • 说的切中要点,让对方清楚知道你的看法,是一种能力;说的圆满得体,让对方自动反省,是一种智慧。
    索班班阅读 154评论 0 0