JS数组

创建数组

let arr = []
let arr1 = new Array() // 或 let arr = Array() 方法可以传递一个参数 为数组长度  Array(6)
let arr2 = Array(6)
console.log(arr2.length) //6
// ES6
let arr3 = Array.form({}) // []
let arr4 = Array.of() // []

数组方法

  • push(), pop()
  • shift(), unshift()
  • join()
  • sort()
  • reverse()
  • concat()
  • slice()
  • splice()
  • toString(), toLocaleString()
  • indexOf(), lastIndexOf() // ES5
  • forEach() // ES5
  • filter() // ES5
  • map() // ES5
  • every() // ES5
  • some() // ES5
  • reduce(), reduceRight()
  • find() //ES6
  • findIndex() // ES6
  • copyWithin() // ES6
  • fill() // ES6
  • entries(), keys(), values()
  • includes()
  • flat(), flatMap()
  • Arrya.prototype.sort()
  • Array.from() // ES6
  • Array.of() // ES6

push(), pop()

push() 在数组的末尾增加一个或多个元素 并返回修改后的长度

let a = []
a.push('hello') // ['hello']
a.push('1', '2') // ['hello', '1', '2']

pop() 删除数组末尾一个元素,返回移除的值

let aPop = a.pop()
console.log(aPop) // 2
console.log(a)  // ['hello', '1']

shift(), unshift()

shift() 删除数组的第一项,并返回删除的值
unshift() 将参数添加到数组开头,并返回数组的新长度

let aShift = a.shift() // 'hello'
console.log(a) // ['1']
let aUnshift = a.unshift('2', '3') // 3
console.log(a) // ['2', '3', '1']

jion()

把数组转换称字符串, 然后使用参数链接一起

let aJoin = a.join() //  2,3,1 默认是 ,
let aJoin2 = a.join('-') // 2-3-1

sort()

将数组中的元素排序并返回排序后的数组。
当不带参数调用sort()时, 数组元素以字母表顺序排序

var a = new Array("banana", "orange", "apple")
a.sort() // ["apple", "banana", "orange"]
var b = [22,66,3,33]
b.sort() // [22, 3, 33, 6] 字母顺序表
b.sort(function(a, b) { return a - b }) // [3, 22, 33, 66] // 数值顺序

reverse()

将数组中的元素顺序颠倒, 返回逆序的数组

var a = [1,3,4]
a.reverse() // [4,3,1]

concat()

创建并返回一个新数组, 它的元素包括调用concat()的元素数组的元素和concat()的每个参数

var a = [1,2,3]
a.concat(4, 5) // [1,2,3,4,5]
console.log(a) // [1,2,3]
a.concat([4,5]) // [1,2,3,4,5]
a.concat([4,5], [6,7]) // [1,2,3,4,5,6,7]
a.concat(4, [5,[6, 7 ]]) // [1,2,3,4,5, [6,7]]

slice()

返回指定数组的一个片段或子数组 参数包头不包尾

var a = [1,2,3,4,5]
a.slice(0,3) // [1,2,3]
a.slice(4) // [4,5]
a.slice(1, -1) // [2,3,4]
a.slice(-3, -2) // [3]

splice()

在数组中插入或删除元素的通用方法。不同于slice()和concat() splice()会修改调用的数组

var a = [1,2,3,4,5,6,7,8]
a.splice(4) // 返回[5,6,7,8] a: [1,2,3,4]
a.splice(1,2) // [2, 3] a:[1,4]

splice的第一个参数指定插入或删除的起始位置,第二个参数指定了要从数组中删除的个数。如果省略第二个参数 则是从起始点开始到结尾全部删除,紧随其后的任意参数指定了需要插入到数组中的元素

toString() toLocaleString()

将其每个元素转化为字符串,并且输出用逗号分隔的字符串

var a = [1,3,4]
a.toString() // 1,3,4

toLocaleString()是toString()的本地化版本

indexOf(), lastIndexOf()

indexOf() 返回某个指定的字符串值在字符串中首次出现的位置
lastIndexOf() 返回某个指定的字符串值在字符串中最后出现的位置

var a = [1,2,3,2,4]
a.indexOf(2) // 1
a.lastIndexOf(2) // 3
a.indexOf(2, 2) // 3 第二个参数是从Array 索引的起始位置, 默认 0

数组的遍历

  • for循环
var arr = [1,2,3,4]
for (let i = 0; i < arr.length; i++ ){
  console.log(arr[i]) // 1,2,3,4
}

for循环有break语句 可以在循环过程中跳过(continue)某一项或者退出(break)

  • forEach()
    从头到尾为数组的每个元素执行一次指定的函数
arr.forEach(function(item) {
  console.log(item) // 1;2;3;4;
})

function 回调参数 当前遍历数组内容, 索引和 数组本身

arr.forEach(function(item, index, arr) {
  console.log(item, index, arr) // 1, 0 ,  [1, 2, 3, 4];  2, 1, [1, 2, 3, 4]; 3, 2, [1, 2, 3, 4]; 4 3  [1, 2, 3, 4]
})
arr.forEach((item, index, array) => array[index]  = item * 2)
arr // [2, 4, 6, 8]

forEach()没有break语句, 如果想要终止 必须把forEach()方法放在一个try块中,并抛出异常。

  • map()
    map()方法将调用的数组的每个元素传递给指定的函数,并返回一个数组,包含改函数的返回值
a = [1,2,3]
b = a.map(x => x*2)
b // [2,4,6]
  • filter()
    filter()方法返回的数组元素是调用数组的一个子集。传递的函数用来逻辑判定,该函数返回true或false。
 a = [1,2,3,4,5]
 b = a.filter(x => x > 2)
 b // [3,4,5]
  • every()和some()
    every()和some()方法返回数组的逻辑判定。它们对数组元素进行指定的函数进行判定,返回true或false
    every():当数组中所有元素都满足判定函数才会返回true
    some():当数组中只要又一个元素满足判定函数就返回true
a  = [1,2,3,4]
a.every(x => x < 10)  // true 全部满足条件
a.every(x => x >2) // false 有一个未满足
a.some(x => x > 3) // true 有一个满足
a.some(x => x > 10) // false  没有一个满足
  • reduce()和reduceRight()
    使用指定的函数将数组元素进行组合,生成单个值。
var a = [1,2,3,4,5]
var sum = a.reduce((x, y) => x + y, 0) // 15 数组求和
var product = a.reduce((x, y) => x * y, 1) // 120 数组求积
var max = a.reduce((x, y) => x > y ? x : y) // 5 数组求最大值

reduce需要两个参数,第一个是执行简化操作的函数,化简函数就是用某种方法把两个值组成一个值,并返回。第二个(可选)的参数是一个传递给函数的初始值。默认为数组的第一个元素
化简函数的参数和forEach(), map()使用的函数不同。es5默认操作函数的值为(数组元素, 元素索引, 和数组本身)。
化简函数的第一个参数是到目前为止的化简操作累计的结果。第一次调用函数时,第一个参数是一个初始值,他就是传递给reduce()的第二个参数。在接下来调用中,这个值就是上次一化简函数的返回值。当不指定初始值的时候,它使用数组的第一个元素为初始值。
在空数组上不带初始值调用reduce()会导致类型错误异常。如果给初始值,那么会直接返回初始值,而不会调用化简函数
redcueRight()的工作原理和reduce()一样,不同的是它从右到左处理数组

不推荐的方法

  • for in
    为Object设计 之所以能够遍历数组 是因为数组的构造函数是Object
    支持 continue 和 break
var a = [1,2,3,4]
for (let i in arr) {
  console.log(i, arr[i]) // 0 1, 1 2, 2 3, 3 4
}
arr.a = 7
for (let i in arr) {
  console.log(i, arr[i]) // 0 1, 1 2, 2 3, 3 4, a 7. for in 会把对象属性遍历出来
}

es6

  • for of
    遍历可遍历的对象, 不只是数组,Object. 可以遍历出这两个常规对象之外的对象, 自定义结构

  • Array.prototype.from
    方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)。
    伪数组:

    • 具有length属性
    • 根据索引储存数据
    • 不能调用数组的方法
    • 可遍历
      比如: function中的 arguments, class 选择器获取的结果. NodeList
      如果伪数组想使用数组的方法, 需要把伪数组转化为数组
// ES5转换方法
let arr = [].slice.call(arguments)
let imgs = [].slice.call(document.querySelectorAll('img'))
// Array.prototype.from
let args = Array.from(arguments)
let imgs = Array.from(document.querySelectAll('img'))
Array.from(arrayLike, mapFn, this) // arrayLike  伪数组, 遍历方法, 函数指向的this
// 遍历方法 对每个元素进行处理,将处理后的值放入返回的数组。

生成一个新的数组

// es5
let array = Array(5)
let array = []
// es6
let arr = Array.from({length: 5})
// 初始化值为1
// es5 需要进行循环赋值
// es6
let arr = Array.from({length: 5}, () => 1)
arr // [1, 1, 1, 1, 1]
  • Array.prototype.of
    用于将一组值,转换为数组。
// 将传入的所有的值转换为数组
Array.of(1, 1, 1, 1, 1) // [1,1,1,1,1 ]
Array.of(3) // [3]
Array.of(3).length // 1
// es5 的 Array
Array() // []
Array(1,2,3) // [1,2,3]
Array(3) // [,,]
  • Array.prototype.fill
    fill方法使用给定值,填充一个数组。
    fill方法还可以接受第二个和第三个参数,用于指定填充的起始位置和结束位置。
let arr = Array(5).fill(1)
arr // [1,1,1,1,1]
arr.fill(2, 1, 3)
arr // [1, 2, 2, 1, 1]
  • find() 和 findIndex()
    找出第一个符合条件的数组成员, 遍历所有成员执行函数, 第一个返回true之后返回该成员,没有找到则返回undefined
[1,2,3,4,5].find(n => n > 2) // 3
[1,2,3,4,5].find((val, index, arr) => n > 2) // 3 三个参数 当前的值、当前的位置和原数组

findIndex方法的用法与find方法非常类似,返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回-1。

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

推荐阅读更多精彩内容

  • ES3数组方法 join() Array.join()方法将数组中所有元素都转化为字符串并连接在一起,返回最后生成...
    markdown阅读 757评论 1 8
  • 数组方法 下面开始介绍数组的方法,数组的方法有数组原型方法,也有从object对象继承来的方法,这里我们只介绍数组...
    祈求者阅读 370评论 0 2
  • 数组的创建 数组的创建有三种方式:构造函数方式、字面量方式、ES6新增的Array.of()方法创建。 构造函数方...
    hnscdg阅读 733评论 0 2
  • JavaScript中创建数组有两种方式 (一)使用 Array 构造函数: var arr1 = new Arr...
    landry阅读 147评论 0 0
  • 中国女排又一次登上世界排球比赛的最高领奖台,实现了郞指导“升国旗、奏国歌”的愿望,为祖国母亲生日献上一份大礼...
    周六十点阅读 151评论 0 0