js-数组方法属性积累

1.join()

var arr = [1,2,3];

console.log(arr.join()); // 1,2,3

console.log(arr.join("-")); // 1-2-3

console.log(arr); // [1, 2, 3](原数组不变)

通过join()方法可以实现重复字符串,只需传入字符串以及重复的次数,就能返回重复后的字符串,函数如下:

function repeatString(str, n) {

return new Array(n + 1).join(str);

}

console.log(repeatString("abc", 3)); // abcabcabc

console.log(repeatString("Hi", 5)); // HiHiHiHiHi

2.push()和pop()

push(): 可以接收任意数量的参数,把它们逐个添加到数组末尾,并返回修改后数组的长度。

pop():数组末尾移除最后一项,减少数组的 length 值,然后返回移除的项。

3.shift() 和 unshift()

shift():删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined 。

unshift:将参数添加到原数组开头,并返回数组的长度 。

4.sort()

自定义排序

function compare(value1, value2) {

if (value1 < value2) {

return -1;

} else if (value1 > value2) {

return 1;

} else {

return 0;

}

}

arr2 = [13, 24, 51, 3];

console.log(arr2.sort(compare)); // [3, 13, 24, 51]

5.reverse()

原数组改变

6.concat()

返回新构建的数组

在没有给 concat()方法传递参数的情况下,它只是复制当前数组并返回副本。

7.slice()

如果有两个参数,该方法返回起始和结束位置之间的项——但不包括结束位置的项。

原数组不变

8.splice()

位置,数量,添加项目

9.indexOf()和 lastIndexOf() (ES5新增)返回的都是正面数的位置

indexOf():接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的开头(位置 0)开始向后查找。

lastIndexOf:接收两个参数:要查找的项和(可选的)表示查找起点位置的索引(向后索引的位置)。其中, 从数组的末尾开始向前查找。返回的是从前向后的位置。

10.forEach() (ES5新增)

参数分别为:遍历的数组内容;第对应的数组索引,数组本身。

var arr = [1, 2, 3, 4, 5];

arr.forEach(function(x, index, a){

console.log(x + '|' + index + '|' + (a === arr));

});

// 输出为:

// 1|0|true

// 2|1|true

// 3|2|true

// 4|3|true

// 5|4|true

11.map() (ES5新增)

map():指“映射”,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。

var arr = [1, 2, 3, 4, 5];

var arr2 = arr.map(function(item){

return item*item;

});

console.log(arr2); //[1, 4, 9, 16, 25]

12.filter() (ES5新增)

filter():“过滤”功能,数组中的每一项运行给定函数,返回满足过滤条件组成的数组。返回为true的项目

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];

var arr2 = arr.filter(function(x, index) {

return index % 3 === 0 || x >= 8;

});

console.log(arr2); //[1, 4, 7, 8, 9, 10]

13.every() (ES5新增)

判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。

var arr = [1, 2, 3, 4, 5];

var arr2 = arr.every(function(x) {

return x < 10;

});

14.some() (ES5新增)

判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。

var arr = [1, 2, 3, 4, 5];

var arr2 = arr.some(function(x) {

return x < 3;

});

console.log(arr2); //true

15.reduce()和 reduceRight() (ES5新增)

这两个方法都会实现迭代数组的所有项,然后构建一个最终返回的值。reduce()方法从数组的第一项开始,逐个遍历到最后。而 reduceRight()则从数组的最后一项开始,向前遍历到第一项。

这两个方法都接收两个参数:一个在每一项上调用的函数和(可选的)作为归并基础的初始值。

传给 reduce()和 reduceRight()的函数接收 4 个参数:前一个值、当前值、项的索引和数组对象。这个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项上,因此第一个参数是数组的第一项,第二个参数就是数组的第二项。

下面代码用reduce()实现数组求和,数组一开始加了一个初始值10。

var values = [1,2,3,4,5];

var sum = values.reduceRight(function(prev, cur, index, array){

return prev + cur;

},10);

console.log(sum); //25

16. Array.from() 将伪数组变成数组,就是只要有length的就可以转成数组(DOM)

let str = '12345'

console.log(Array.from(str))    // ["1", "2", "3", "4", "5"]

let obj = {0:'a',1:'b',length:2}

console.log(Array.from(obj))  // ["a", "b"]

17.Array.of() 将一组值转换成数组,类似于声明数组

let str = '11'

console.log(Array.of(str))  // ['11']

等价于

console.log(new Array('11'))  // ['11]

但是new Array()有缺点,就是参数问题引起的重载

console.log(new Array(2))  //[empty × 2]  是个空数组

console.log(Array.of(2))    // [2]

18.arr.copyWithin() 在当前数组内部,将制定位置的数组复制到其他位置,会覆盖原数组项,返回当前数组

参数: target --必选 索引从该位置开始替换数组项

      start --可选 索引从该位置开始读取数组项,默认为0.如果为负值,则从右往左读。

      end --可选 索引到该位置停止读取的数组项,默认是Array.length,如果是负值,表示倒数

let arr = [1,2,3,4,5,6,7]

let arr1 = arr.copyWithin(1)

console.log(arr1)  // [1, 1, 2, 3, 4, 5, 6]

let arr2 = arr.copyWithin(1,2)

console.log(arr2)  // [1, 3, 4, 5, 6, 7, 7]

let arr3 = arr.copyWithin(1,2,4)

console.log(arr3)  // [1, 3, 4, 4, 5, 6, 7]

19.arr.find(callback) 找到第一个符合条件的数组成员

let arr = [1,2,3,4,5,2,4]

let arr1 = arr.find((item, index, array) => item > 2)

console.log(arr1)  // 3

20.arr.findIndex(callback) 找到第一个符合条件的数组成员的索引值

let arr = [1,2,3,4,5]

let arr1 = arr.findIndex((item, index, array) => item > 3)

console.log(arr1)  // 3

21.arr.fill(target, start, end) 使用给定的值,填充一个数组,ps:填充完后会改变原数组

参数: target -- 待填充的元素

      start -- 开始填充的位置-索引

        end -- 终止填充的位置-索引(不包括该位置)

复制代码

let arr = [1,2,3,4,5]

let arr1 = arr.fill(5)

console.log(arr1)  // [5, 5, 5, 5, 5]

console.log(arr)  // [5, 5, 5, 5, 5]

let arr2 = arr.fill(5,2)

console.log(arr2)

let arr3 = arr.fill(5,1,3)

console.log(arr3)

22.arr.includes() 判断数中是否包含给定的值

let arr = [1,2,3,4,5]

let arr1 = arr.includes(2) 

console.log(arr1)  // ture

let arr2 = arr.includes(9)

console.log(arr2)    // false

let arr3 = [1,2,3,NaN].includes(NaN)

console.log(arr3)  // true

23.arr.keys() 遍历数组的键名

let arr = [1,2,3,4]

let arr2 = arr.keys()

for (let key of arr2) {

    console.log(key);  // 0,1,2,3

}

24.arr.values() 遍历数组键值

let arr = [1,2,3,4]

let arr1 = arr.values()

for (let val of arr1) {

    console.log(val);  // 1,2,3,4

}

25. arr.entries() 遍历数组的键名和键值

let arr = [1,2,3,4]

let arr1 = arr.entries()//返回Array Iterator

for (let e of arr1) {

//e 返回数组,第一个是索引,第二个是值

//[0, 1]

//[1, 2]

//[2, 3]

//[3, 4]

}

26.Iterator遍历过程:

  - 创建一个指针对象,指向当前数据结构的起始位置;

  - 调用next方法,可以将指针指向数据结构的第一个成员,返回一个包含value(数组,第一项索引,第二项值)和done属性的对象;

  - 继续调用next方法,......以此类推,直到指向结束位置。

27.for...of适用于数组、Set、Map、类数组对象(arguments、nodelist)、Generator、字符串。

28.for...in 和 for...of

  - 前者只能获取对象的键名,后者可以得到键值;

  - 对于数组,前者可以返回数组上的所有属性,后者只能返回具有数字索引的属性;

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

arr.d = 'hello';

//主要为遍历对象而设计;不适用与遍历数组;

for (let i in arr) {

  console.log(i); // '0', '1', '2', 'd'

}

for (let i of arr) {

  console.log(i); //  'a, 'b', 'c'

}

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

推荐阅读更多精彩内容

  • //JS数组常用方法及其应用/** * 1.push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组...
    李二狗的星球阅读 438评论 0 0
  • 1、新的声明方式 以前我们在声明时只有一种方法,就是使用var来进行声明,ES6对声明的进行了扩展,现在可以有三种...
    令武阅读 976评论 0 7
  • 数组方法 下面开始介绍数组的方法,数组的方法有数组原型方法,也有从object对象继承来的方法,这里我们只介绍数组...
    祈求者阅读 365评论 0 2
  • 品牌塑造价值,服务拉开差距,企业的品牌价值要通过服务得以提升。 海底捞的服务可以用16个字来概括:有求必应,无微不...
    zqk阅读 2,132评论 0 2
  • Ⅰ.从本文章中学到的最重要的概念: 保存初心,找到自己喜欢做的事,无论多难,去坚持。 Ⅱ.在文章中学到的怦然心动的...
    147李源阅读 262评论 5 0