Javascript:数组常用方法整理

下面以var arr = ['x', 'u', 'e', 'y', 'i', 'n', 'g']为例

修改器方法:

修改器方法会改变原数组

1. arr.pop() && arr.push()

会改变原数组

arr.pop()删除数组最后一个元素,并返回这个元素

arr.pop() // "g"

arr.push()在数组末尾增加一个元素,返回数组的新长度

arr.push('l') // 8
arr // ["x", "u", "e", "y", "i", "n", "g", "l"]

2. arr.shift() && arr.unshift()

arr.shift() 删除数组开头第一个元素,并返回这个元素

arr.shift() // "x"

arr.unshift() 在数组开头增加一个元素,返回数组新长度。

arr.unshift('l')  // 8 
arr // ["l", "x", "u", "e", "y", "i", "n", "g"]

3. arr.reverse()

会改变原数组

数组倒序,返回倒序后的数组

arr.reverse() // ["g", "n", "i", "y", "e", "u", "x"]

4. arr.sort() || arr.sort(compareFunction)

对数组进行排序,并返回排好序的当前数组。(写得这么拗口是为了强调是原数组的顺序改变
.sort()使用的是就地排序算法,且不一定稳定
(就地排序意思是直接在原数组上排序。稳定指的是两个相等的元素排好序后前后顺序不变)

默认排序顺序是根据字符串Unicode码点。
这意味着:

var scores = [1, 10, 21, 2]; 
scores.sort();  // [1, 10, 2, 21]
// 10在2之前,因为在 Unicode 指针顺序中"10"在"2"之前

不过.sort()可以接受一个函数作为参数,自己指定排序规则:

var scores = [1, 10, 21, 2]; 
scores.sort(function (a, b) { // 从小到大排序
  return a - b
}) // [ 1, 2, 10, 21 ]

函数compareFunction 的规则如下:

  • 如果 compareFunction(a, b) 小于 0 ,那么 a 会被排列到 b 之前;
  • 如果 compareFunction(a, b) 等于 0 , a 和 b 的相对位置不变。
    备注: ECMAScript 标准并不保证这一行为,而且也不是所有浏览器都会遵守(例如 Mozilla 在 2003 年之前的版本);
  • 如果 compareFunction(a, b) 大于 0 , b 会被排列到 a 之前。
  • compareFunction(a, b) 必须总是对相同的输入返回相同的比较结果,否则排序的结果将是不确定的。

5. arr.splice(start, deleteCount, item1, item2, ...)

修改数组,从start开始,删除deleteCount个元素,再插入后面的item1, item2, ...

// 从下标0开始,删除一个元素,并插入‘X'
arr.splice(0, 1, 'X') // ["x"]
arr // ["X", "u", "e", "y", "i", "n", "g"]

访问方法:

访问方法不会改变原数组,一般都是返回一个新数组

1. arr1.concat(arr2)

合并arr1arr2

var arr1 = ["x", "u", "e"]
var arr2 = ["y", "i", "n", "g"]
arr1.concat(arr2) // ["x", "u", "e", "y", "i", "n", "g"]

2. arr.includes(searchElement, fromIndex)

fromIndex开始查找searchElement,找到了返回true,找不到返回false
fromIndex可省略,默认从下标0开始找。

arr.includes('u') // true
arr.includes('u', 2) // false

3. arr.join(separator)

数组合并成一个字符串,每一个元素用separator隔开。
separator可省略,默认为,

arr.join() // "x,u,e,y,i,n,g"
arr.join('') // "xueying"

4. arr.slice(begin, end)

抽取数组在[begin,end)区间内的元素,返回一个新数组。

arr.slice(0, 3) // ["x", "u", "e"]

5. arr.toString()

arr.toString() // "x,u,e,y,i,n,g"

6. arr.indexOf(searchElement[, fromIndex = 0])

返回searchElement的下标,没有则返回 -1
可以指定fromIndex表示从哪个下标开始查找,默认为下标0

arr.indexOf('u') // 1
arr.indexOf('u', 2) // -1

7. arr.lastIndexOf(searchElement[, fromIndex = arr.length - 1])

找到数组中最后一个和searchElement相等的元素的下标。
可以指定fromIndex表示从哪个下标开始查找,默认从数组最后一个元素开始。

var arr = ["x", "u", "l", "e", "y", "i", "n", "g", "l"]
arr.lastIndexOf('l') // 8

迭代方法

1. arr.forEach()

语法:

array.forEach(callback(currentValue, index, array){
    //do something
}, thisArg)

对数组每一个元素执行callback函数。

callback函数接收3个参数:

  1. currentValue:当前元素的值
  2. index: 当前元素的下标
  3. array:原数组

thisArg:可选,用作callback函数的this值。

var arr = ['x', 'u', 'e', 'y', 'i', 'n', 'g']
arr.forEach((element, index, array) => console.log('arr[' + index + '] = ' + element))
/* 
arr[0] = x
arr[1] = u
arr[2] = e
arr[3] = y
arr[4] = i
arr[5] = n
arr[6] = g
*/

2. arr.every(callback[, thisArg]) && arr.some(callback[, thisArg])

arr.every(callback[, thisArg])
测试数组的 所有 元素是否都通过了callback函数的测试。
全部通过返回true ,否则返回false
thisArg指定this值。

// 格式和forEach方法没区别
var arr = ['x', 'u', 'e', 'y', 'i', 'n', 'g']
console.log(arr.every((element, index, array) => element === element.toLowerCase())) // 数组中的元素是否都为小写
// true

arr.some(callback[, thisArg])
测试数组的 某些 元素是否全部通过了callback函数的测试。

// 语法和forEach方法没区别
var arr = ['X', 'u', 'e', 'y', 'i', 'n', 'g'] // 第一个元素大写
console.log(arr.some((element, index, array) => element === element.toLowerCase())) // 数组中是否有小写的元素
// true

3. arr.filter(callback[, thisArg])

过滤器,创建一个新数组, 其包含通过所提供函数实现的测试的所有元素
语法还是跟forEach方法没区别。

var arr = ['X', 'u', 'e', 'y', 'i', 'n', 'g'] // 第一个元素大写
console.log(arr.filter((element, index, array) => element === element.toLowerCase())) 
// [ 'u', 'e', 'y', 'i', 'n', 'g' ]

4. arr.find(callback[, thisArg]) && arr.findIndex(callback[, thisArg])

arr.find(callback[, thisArg])
语法同上。
返回数组中第一个满足callback函数的元素的值。否则返回 undefined

var arr = ['X', 'u', 'e', 'y', 'i', 'n', 'g'] // 第一个元素大写
console.log(arr.find((element, index, array) => element === element.toLowerCase()))
// "u"

arr.findIndex(callback[, thisArg])
语法同上。
返回数组中第一个满足callback函数的元素的索引。否则返回-1。

var arr = ['X', 'u', 'e', 'y', 'i', 'n', 'g'] // 第一个元素大写
console.log(arr.findIndex((element, index, array) => element === element.toLowerCase()))
// 1

5. arr.entries()

(迭代器)返回一个新的Array Iterator对象,该对象包含数组中每个索引的键/值对。
跟Python中迭代器一样,用.next()访问下一键值对。

var iterator = arr.entries();
iterator.next() // {value: Array(2), done: false} done表示迭代是否已经完成
iterator.next().value //  [1, "u"]

6. arr.keys() && arr.values()

arr.keys()
返回一个新的Array迭代器,它包含数组中每个索引的键。

var iterator = arr.keys();
iterator.next() // {value: 0, done: false}
iterator.next().value // 1
// 不断next直到最后一个
console.log(iterator.next())  // {value: undefined, done: true}

arr.values()
返回一个新的 Array Iterator 对象,它包含数组每个索引的值。

PS: Chrome 未实现,Firefox未实现,Edge已实现。
Chrome 及Firefox可以用"arrSymbol.iterator"方法来代替values()方法。

var arr = [1,2,3,4,5]
var i = arr[Symbol.iterator]()
i.next() // {value: 1, done: false}
i.next() // {value: 2, done: false}

7. arr.map(callback)

创建一个新数组,其结果是该数组中的每个元素都调用callback函数后返回的结果。
语法:

arr.map(function callback(currentValue, index, array) { 
    // Return element for new_array 
}[, thisArg])

例子:

arr.map((element, index, array) => element.toUpperCase()) // ["X", "U", "E", "Y", "I", "N", "G"]

8. arr.reduce(callback[, initialValue])

累加器, 数组中的每个元素(从左到右)应用一个函数,将其减少为单个值。

callback函数接收4个参数:

  1. accumulator:累加器累加回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue
  2. currentValue:数组中正在处理的元素
  3. currentIndex:数组中正在处理的当前元素的索引。
  4. array:原数组

initialValue:用作第一个调用 callback的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。

回调函数第一次执行时,accumulator 和currentValue的取值有两种情况:

  1. 调用reduce时提供initialValue,accumulator取值为initialValue,currentValue取数组中的第一个值。
  2. 没有提供 initialValue,accumulator取数组中的第一个值,currentValue取数组中的第二个值。
// 取最大值
var arr = [1, 2, 3, 4, 5, 6]
console.log(arr.reduce((accumulator, currentValue) =>  Math.max(accumulator, currentValue)))
// 6

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

推荐阅读更多精彩内容