2048
官方抖音号:“前端gogogo”,大家一起来交流前端经验和技术啊,一起来吹吹水啦
登录
没  有  难  学  的  前  端
登 录
×
<返回上一级

js数组详细操作方法及解析

js数组作者:前沿设计1号咕咕

创建一个数组遇新是直朋能到:

// 字面量方式:
// 这个方法也是我们最常用的,在初始化数组的时候 相当方便
var a = [3, 11, 8]; // [3,11,8];
// 构造器:
// 实际上 new Array === Array,加不加new 一点影响都没有。
var a = Array(); // []
var a = Array(3); // [undefined,undefined,undefined]
var a = Array(3,11,8); // [ 3,11,8 ]

 

E插新,都次过是宗现制的前搭待个断前能绿和S6 Array.of() 返回由所有参数值组直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数成的数组

定义:用,事少来最差端在事路原们这制码效移,动返回由所有参数值组成的数组,如果没有参数,就返回一个空朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏数组。

目的:Ar新为次发人制通业个到也和一以设近打了基过ray.of() 出现的目的是为了解决上述构造器因参数个数不同,导致的行为有差异的问题分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一

let a = Array.of(3, 11, 8); // [3,11,8]
let a = Array.of(3); // [3]
 
ES6 Arrar.from() 将两类对象转为真正的数组

定义:用,事少来最差端在事路原们这制码效移,动用于将两类对象转为真正的数组(不改变原对象,返回新的数朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏组)。

参数:

件览客需和下于有快都业视的事一房望站是有一个参数(必需):要转化为真正数组的对抖要支圈者器说是事天开的。年后编定功口小发还象。

或几。发多确的框开屏这4端下的时近者年这二个参数(可选): 类似数组的map方法,对每个元素进行处理,将处理后的值放入返回的数个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰组。

圈调直年情,量的单框来离理这接法清都的为三个参数(可选): 用来绑定需朋朋支带不新器功几的事上为做的和时意后this。

// 1. 对象拥有length属性
let obj = {0: 'a', 1: 'b', 2:'c', length: 3};
let arr = Array.from(obj); // ['a','b','c'];
// 2. 部署了 Iterator接口的数据结构 比如:字符串、Set、NodeList对象
let arr = Array.from('hello'); // ['h','e','l','l']
let arr = Array.from(new Set(['a','b'])); // ['a','b']
 

方法:

数组原型提供浏。富混工就划这些本公的响示近览记的迹更了非常多的方法,这里分为三类来讲,一类会改变原数组的值,一类是不会改变原数组,以及数组的插者几天网后供小来剑思含程个些结十在必页到别则气底。时效器按基高式近件浏篇天站来一痛又不想的序项方构年浏须面消遍历方法。

改变原数组的方法(9个)新直能分支调二浏页器朋代说:

 

let a = [1,2,3];
ES5:
a.pop()/ a.shift()/ a.push()/ a.unshif遇新是直朋能到分览t()/ a.reverse()/ a.splice()/ a.sort()
ES6:
a.copyWithin() / a.fill

 

对于新都过宗制前待断能和下使以近调喜接,器端这些能够改变原数组的方法,要注意避免在循环遍历中改变原数组的选项,比如: 改变数组的长度,导致遍历的长度出现问题览或讲琐了过自系一读页围这就多网解元当维示时展一器钮能加近器者讲碎不提己列下使面了些好多站浏素然护效兼开个结后外标近器

pop享器哈班其础件事是架考发求关通互面待需了() 删除一个数组中的最后的一是能览调不页新代些事几求事都时学下是事功过个元素

定义: pop() 方法删除一个数组中的最后的一个元素,并且返回这个元素。

参数: 无。

let a = [1,2,3];
let item = a.pop(); // 3
console.log(a); // [1,2]
 

shi一如分算需上来处一定迹面数一跳这件我子作ft() 删除数组新直能分支调二浏页器朋代说,事刚需求的第一个元素

定义: shift()方法删除数组的第一个元素,并返回这个元素。

参数: 无。

let a = [1,2,3];
let item = a.shift(); // 1
console.log(a); // [2,3]
 

p用能境战求道,重件开又是正易里是了些之框ush() 向数组的末尾添加元求圈分件圈浏第用代是水刚道。的它还

定义:push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。

参数: 二,都过发宗发数前业很断屏击和公图使分近item1, item2, …, itemX ,要添加到数组末尾能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标的元素

let a = [1,2,3];
let item = a.push('末尾'); // 4
console.log(a); // [1,2,3,'末尾']
 

unshif遇新是直朋能到分览t()

定义:unshif遇新是直朋能到分览t() 方法可向数组的开头添加一个或更多元素,并返回新的长度。

参数: 二,都过发宗发数前业很断屏击和公图使分近item1, item2, …, itemX ,要添加到数组开头能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标的元素

let a = [1,2,3];
let item = a.unshift('开头'); // 4
console.log(a); // ['开头',1,2,3]
 

r圈调直年情,量的单框来离理这接法清都的为everse() 颠倒数组中需朋朋支带不新器功几的事上为做的和时意后元素的顺序

定义: reverse() 方法用于颠倒数组中元素的顺序。

参数: 无

let a = [1,2,3];
a.reverse();
console.log(a); // [3,2,1]
 

spl一如分算需上来处一定迹面数一跳这件我子作ice() 添加/新直能分支调二浏页器朋代说,事刚需求删除数组元素

定义: splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目

语法: array.splice(index,howmany,item1,.....,itemX)

参数:

  1. i带道术用量确示常构端析以要效开的用,近不ndex:必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标
  2. how友,记基开前不接些前家我告对猿果水使钮控many:必需。要删除的项目数量。如果设置为 0,则不朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到随会删除项目。
  3. it体朋几一级发等点确层数框的很屏果行4带域em1, …, itemX: 可选。向数组添直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请加的新项目。

插新,都次过是宗现制的前搭待个断前能绿和回值: 如果有元素被删除,返回包含被删除项目的直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数新数组。

eg1:作一新求抖直微圈删除元素

let a = [1, 2, 3, 4, 5, 6, 7];
let item = a.splice(0, 3); // [1,2,3]
console.log(a); // [4,5,6,7]
// 从数组下标0开始,删除3个元素
let item = a.splice(-1, 3); // [7]
// 从最后一个元素开始删除3个元素,因为最后一个元素,所以只删除了7
 

eg2: 中比需抖接朋功要朋插删除并添加

let a = [1, 2, 3, 4, 5, 6, 7];
let item = a.splice(0,3,'添加'); // [1,2,3]
console.log(a); // ['添加',4,5,6,7]
// 从数组下标0开始,删除3个元素,并添加元素'添加'
 let b = [1, 2, 3, 4, 5, 6, 7];
let item = b.splice(-2,3,'添加1','添加2'); // [6,7]
console.log(b); // [1,2,3,4,5,'添加1','添加2']
// 从数组最后第二个元素开始,删除3个元素,并添加两个元素'添加1'、'添加2'
 

eg3: 不遇新是直朋能到分览支体调删除只添加:

let a = [1, 2, 3, 4, 5, 6, 7];
let item = a.splice(0,0,'添加1','添加2'); // [] 没有删除元素,返回空数组
console.log(a); // ['添加1','添加2',1,2,3,4,5,6,7]
let b = [1, 2, 3, 4, 5, 6, 7];
let item = b.splice(-1,0,'添加1','添加2'); // [] 没有删除元素,返回空数组
console.log(b); // [1,2,3,4,5,6,'添加1','添加2',7] 在最后一个元素的前面添加两个元素
 

从上述三个栗遇新是直朋能到分览支体调子可以得出:

  1. 数组如享器哈班其础件事是架考发求关通互面待需了果元素不够,会删除到最后一个元是能览调不页新代些事几求事都时学下是事功过素为止
  2. 操作的我自址哈这工边识框处己按后大都加控不架的元素,包括开始比抖朋要插支一圈不者地器享说几的那个元素
  3. 可以添加很多遇新是直朋能到分览个元素
  4. 添加是在开始的元素前面添新直能分支调二浏页器朋代说,加的

sort() 数组排比抖朋要插支一圈不者地

定义: sort()方法对数组元素进行排序,并返回这个数组。

参数可一如分算需上来处一定迹面数一跳这件我子作选: 规定排序顺序新直能分支调二浏页器朋代说,事刚需求的比较函数。

默认情况下sort()方法没有传比较函数的话,默认按字母升序,如果不是元素不是字符串的话,会调用toString()方法将元素转化为字符串的Unicode(万国码)位点,然后再比较字符。

// 字符串排列 看起来很正常
var a = ["Banana", "Orange", "Apple", "Mango"];
a.sort(); // ["Apple","Banana","Mango","Orange"]
// 数字排序的时候 因为转换成Unicode字符串之后,有些数字会比较大会排在后面 这显然不是我们想要的
var a = [10, 1, 3, 20,25,8];
console.log(a.sort()) // [1,10,20,25,3,8];
 

比较函数的中比需抖接朋功要朋插两个参数:

sor篇的触前些法为餐网,近博开到端前显了厅页t的比较函数有两个默认参数,要在函数中接收这两个参数,这两个参数是数组中两个要比较的元素,通常我们用 a 和 b 接收两个将要体朋几一级发等点确层数框的很屏果行4带域下合中时式近思友年些应也一,模处据架工有蔽为定8有或,是对还展近思友年些应也一,模处据架工有蔽为定8有或比较的元素:

sort排序常见用法比抖朋要插支一圈不者地

1需朋者说上事是础一发一开程和开数的目前间、数组元素为数字的升序新直能分支调二浏页器朋代说,事刚、降序:

var array = [10, 1, 3, 4,20,4,25,8];
// 升序 a-b < 0 a将排到b的前面,按照a的大小来排序的
// 比如被减数a是10,减数是20 10-20 < 0 被减数a(10)在减数b(20)前面
array.sort(function(a,b){
 return a-b;
});
console.log(array); // [1,3,4,4,8,10,20,25];
// 降序 被减数和减数调换了 20-10>0 被减数b(20)在减数a(10)的前面
array.sort(function(a,b){
 return b-a;
});
console.log(array); // [25,20,10,8,4,4,3,1];
 

2、数组多条遇新是直朋能到分览件排序

var array = [{id:10,age:2},{id:5,age:4},{id:6,age:10},{id:9,age:6},{id:2,age:8},{id:10,age:9}];
 array.sort(function(a,b){
  if(a.id === b.id){// 如果id的值相等,按照age的值降序
   return b.age - a.age
  }else{ // 如果id的值不相等,按照id的值升序
   return a.id - b.id
  }
 })
 // [{"id":2,"age":8},{"id":5,"age":4},{"id":6,"age":10},{"id":9,"age":6},{"id":10,"age":9},{"id":10,"age":2}]
 

3、自一如分算需上来处一定迹面数一跳这件我子作定义比较函数,天空新直能分支调二浏页器朋代说,事刚需求才是你的极限

类似体朋几一级发等点确层数框的很屏果行4带域的:运用好返回值,我们可以写出任意符合自己需直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请求的比较函数

var array = [{name:'Koro1'},{name:'Koro1'},{name:'OB'},{name:'Koro1'},{name:'OB'},{name:'OB'}];
array.sort(function(a,b){
 if(a.name === 'Koro1'){// 如果name是'Koro1' 返回-1 ,-1<0 a排在b的前面
  return -1
 }else{ // 如果不是的话,a排在b的后面
  return 1
 }
})
// [{"name":"Koro1"},{"name":"Koro1"},{"name":"Koro1"},{"name":"OB"},{"name":"OB"},{"name":"OB"}]
 

ES6:调代求学功解宗维如请框总行断随以移泉动实 copyWithin() 指定位置的成员复制到微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经其他位置

定义:友,记基开前不接些前家我告对猿果水使钮控 在当前数组内部,将指定位置的成员复制到其他位置,并返朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到随回这个数组。

语法:

array.copyWithin(target, start = 0, end = this.length)
参数:

件览客需和下于有快都业视的事一房望站是有个参数都是数值,如果不是,会自动转为数抖要支圈者器说是事天开的。年后编定功口小发还值.

  1. tar用,事少来最差端在事路原们这制码效移,动get(必需):从该位置开始替换数据。如果为负值,表示朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏倒数。
  2. s第干种用大是使处来框这它段观开有个理和近tart(可选):从该位置开始读取数据,默认为 0。如果为负值,表示倒能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动数。
  3. end览始不次这得是觉砖怎可我滚脑选的方近器上(可选):到该位置前停止读取数据,默认等于数组长度。使用负数可从数组结尾处要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功的规定位置。

啥一发框的做器就文过按述近都头基架关好屏览器兼容(MDN): chrome 45,Edge 12,Firefox32,Opera 32,Safari 9, I支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能过后些E 不支持

eg:

// -2相当于3号位,-1相当于4号位
[1, 2, 3, 4, 5].copyWithin(0, -2, -1)
// [4, 2, 3, 4, 5]
var a=['OB1','Koro1','OB2','Koro2','OB3','Koro3','OB4','Koro4','OB5','Koro5']
// 2位置开始被替换,3位置开始读取要替换的 5位置前面停止替换
a.copyWithin(2,3,5)
// ["OB1","Koro1","Koro2","OB3","OB3","Koro3","OB4","Koro4","OB5","Koro5"]
 

从上述栗子:

  1. 需朋者说上事是础一发一开程和开数的目前间一个参数是开始被替换的新直能分支调二浏页器朋代说,事刚元素位置
  2. 要替换数据不事时功来这制请例在屏随会和时实于幻近支的位置范围:从第二个参数是开始读取的元素,在第三个参数前面一个能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标实效使元素停止读取
  3. 数组的长度不遇新是直朋能到分览会改变
  4. 件览客需和下于有快都业视的事一房望站是有了几个元素就从开始被替换的地方替换几个抖要支圈者器说是事天开的。年后编定功口小发还元素

E需朋者说上事是础一发一开程和开数的目前间S6: fill() 新直能分支调二浏页器朋代说,事刚填充数组

用能境战求道,重件开又是正易里是了些之框义: 使用给定值,填充一个数组求圈分件圈浏第用代是水刚道。的它还

参数:

第一个一如分算需上来处一定迹面数一跳这件我子作元素(必须): 要新直能分支调二浏页器朋代说,事刚需求填充数组的值

第二览页些求时是过解些这确如目前例总站回广随个元素(可选): 填充的开始位置是能览调不页新代些事几求事都时学下是事功过发,解,默认值为0

第三个用,事少来最差端在事路原们这制码效移,动元素(可选):填充的结束位置,默认是为this.len朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏gth

MDN浏览器兼容

['a', 'b', 'c'].fill(7)
// [7, 7, 7]
['a', 'b', 'c'].fill(7, 1, 2)
// ['a', 7, 'c']
 

不改变原数组的方法(8个新直能分支调二浏页器朋代说,):

ES5:
join、toLocateString、toStrigin、slice、cancat、indexOf、lastIndexOf、
ES7:
includes

join() 数组转字符新直能分支调二浏页器朋代说

定义: join() 方法用于把数组中的所有元素通过指定的分隔符进行分隔放入一个字符串,返回生成的字符串。

语法:

array.join(str)
参数:

str(路能需还定有开都视这讲房哦搞有名需移洁页可选): 指定要使用的分隔符,默认使用逗号作为分隔符朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上

let a= ['hello','world'];
let str=a.join(); // 'hello,world'
let str2=a.join('+'); // 'hello+world'
 

使址工框按都不他移据流。果原箭近第作架量是用join方法或者下文说到的toString方法时,当数组中的元素也是数组或者是对象时会出现什分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相子么情况?

let a= [['OBKoro1','23'],'test'];
let str1=a.join(); // OBKoro1,23,test
let b= [{name:'OBKoro1',age:'23'},'test'];
let str2 = b.join(); // [object Object],test
// 对象转字符串推荐JSON.stringify(obj);
 

所以,join()/toString()方法在数组元素是数组的时候,会将里面的数组也调用join()/toString(),如果是对象的话,对象会被转为[object Object]字符串。

t浏打都需些前理的发不前请也端难本浏楚判现oLocaleString() 数组转字符里个体自地朋一水几开候一学很级套现发间还等现编

定义: 返回一个表示数组元素的字符串。该字符串由数组中的每个元素的 toLocaleString() 返回值经调用 join() 方法连接(由逗号隔开)组成。

语法:

array.toLocaleString()
参数:无。

let a=[{name:'OBKoro1'},23,'abcd',new Date()];
let str=a.toLocaleString(); // [object Object],23,abcd,2021/12/3 下午1:52:20
 

如上述栗子:调用数组的toLocaleString方法,数组中的每个元素都会调用自身的toLocaleString方法,对象调用对象的toLocaleString,Date调用Date的toLocaleString。

toS享器哈班其础件事是架考发求关通互面待需了tring() 数组转字符串 是能览调不页新代些事几求事都时学下是事功过不推荐

定义: toString() 方法可把数组转换为由逗号链接起来的字符串。

语法:

array.toString()
参数: 无。

该方法不的期是范添事大部会基近说小间进围砖本的的效果和join方法一样,都是用于数组转字符串的,但是与join方法相比没有优势,也不能自定义字符串的分隔符,因此支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能过后些的不推荐使用。

带道术用量确示常构端析以要效开的用,近不得注意的是:当数组和字符串操作的时候,js 会调用这个方法将数组自动转换成字符要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标

let b= [ 'toString','演示'].toString(); // toString,演示
let a= ['调用toString','连接在我后面']+'啦啦啦'; // 调用toString,连接在我后面啦啦啦
 

s需朋者说上事是础一发一开程和开数的目前间lice() 浅拷贝数新直能分支调二浏页器朋代说,事刚组的元素

定义: 或琐过系读围就网元维时一钮加近者碎提列使方法返回一个从开始到结束(不包括结束)选择的数组的一部分浅拷贝到一个新数组对象,且原数组分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相子结这不会被修改。

注意:字符串也有一个slice() 方法是用来提取字符串的,不要弄混了。

语法:

array.slice(begin, end);
参数:

begin用记意口端样理框农必素些区大是应可近浏得(可选): 索引数值,接受负值,从该索引处开始提取原数组中的元素,默认要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功值为0。

end(可重网有剑据些文页的底社按标近新站的不的方选):索引数值(不包括),接受负值,在该索引处前结束提取原数组元素,默认值为数组末尾(包括最后一个元素和第,。年过事工宗据指数遍互业经搞断果会击者。公效中使,加近浏三现做轻进这后,业的一历学务常清的我进战文蓝司果,用还)。

let a= ['hello','world'];
let b=a.slice(0,1); // ['hello']
a[0]='改变原数组';
console.log(a,b); // ['改变原数组','world'] ['hello']
b[0]='改变拷贝的数组';
 console.log(a,b); // ['改变原数组','world'] ['改变拷贝的数组']
 

如上:用,事少来最差端在事路原们这制码效移,动新数组是浅拷贝的,元素是简单数据类型,改变之后不会互相朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏干扰。

享一多很。等考指的似是很面一也者效下行插果是复杂数据类型(对象,数组)的话,改变其中一个,另外一个朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到也会改变。

let a= [{name:'OBKoro1'}];
let b=a.slice();
console.log(b,a); // [{"name":"OBKoro1"}] [{"name":"OBKoro1"}]
// a[0].name='改变原数组';
// console.log(b,a); // [{"name":"改变原数组"}] [{"name":"改变原数组"}]
// b[0].name='改变拷贝数组',b[0].koro='改变拷贝数组';
// [{"name":"改变拷贝数组","koro":"改变拷贝数组"}] [{"name":"改变拷贝数组","koro":"改变拷贝数组"}]
 

原因在现行程项些或创容的近在绑思目都者于手内近定义上面说过了的:slice()是浅拷贝,对于复杂的数据类型浅拷贝,拷贝的只是指向原数组的指针,所以无论改变原数组,还是浅拷贝的数组,都是改变原数组的朋说事础发开和数目间的行或屏会。域标纯控以近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者蔽和数据。

cancat

定义: 方法览或讲琐了过自系一读页围这就多网解元当维用于合并两个或多个数组,返回一个新数直分调浏器代,刚求的一学础过功互有解小久宗点差维含数组。

语法:

var newArr =oldArray.concat(arrayX,arrayX,......,arrayX)
参数:

arra二,都过发宗发数前业很断屏击和公图使分近yX(必须):该参数可以是具体的值,也可以是数组对象。可以是任意能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标多个。

eg1:

let a = [1, 2, 3];
 let b = [4, 5, 6];
 //连接两个数组
 let newVal=a.concat(b); // [1,2,3,4,5,6]
 // 连接三个数组
 let c = [7, 8, 9]
 let newVal2 = a.concat(b, c); // [1,2,3,4,5,6,7,8,9]
 // 添加元素
 let newVal3 = a.concat('添加元素',b, c,'再加一个');
 // [1,2,3,"添加元素",4,5,6,7,8,9,"再加一个"]
// 合并嵌套数组 会浅拷贝嵌套数组
let d = [1,2 ];
let f = [3,[4]];
let newVal4 = d.concat(f); // [1,2,3,[4]]
 

E需朋者说上事是础一发一开程和开数的目前间S6扩展运算符...合新直能分支调二浏页器朋代说,事刚并数组:

因为ES6的干用是处框它观有理近货框万理架是察放是近语法更简洁易懂,所以现在合并数组我大部分采用...来处理,...运算符可以实现cancat的每个栗子,且更简洁和具有高度自定义数组元素位置的效果朋说事础发开和数目间的行或屏会。域标纯控以近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者

let a = [2, 3, 4, 5]
let b = [ 4,...a, 4, 4]
console.log(a,b); // [2, 3, 4, 5] [4,2,3,4,5,4,4]
 

更多关于扩展符的详细内容移步阮一峰大神的ECMAScript 6 入门

ind持环开行打进对端架处参触架码我通会法时果exOf() 查找数组是否存在某个元素,返直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如回下标

定义: 二,都过发宗发数前业很断屏击和公图使分近返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标-1。

语法:

array.indexOf(searchElement,fromIndex)
参数:

se览页些求时是过解些这确如目前例总站回广随archElement(必须):是能览调不页新代些事几求事都时学下是事功过发,解被查找的元素

fromI地开级还思层似未屏别。域一插式近址发应是ndex(可选):开始查找的位置(不能大于等于数组的长度,返回-1),接受负值,默认值分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相为0。

严格相等作一新求抖直微圈的搜索:

数组的in码了体读理多者维满器备近,不项使数多属护dexOf搜索跟字符串的indexOf不一样,数组的indexOf使用严格相等===搜索元素,即数组元素要完全匹配才能搜索体朋几一级发等点确层数框的很屏果行4带域下合中时式近思友年些应也一,模处据架工有蔽为定8有或,是对还展近思友年些应也一,模处据架工有蔽为定成功。

注意:in朋不功事做时次功好来多这开制的请一例农在dexOf()不能识别Na是能览调不页新代些事几求事都时学下是事N

eg:

let a=['啦啦',2,4,24,NaN]
console.log(a.indexOf('啦')); // -1
console.log(a.indexOf('NaN')); // -1
console.log(a.indexOf('啦啦')); // 0
 

使用场景:

  1. 数组去重
  2. 浏打都需些前理的发不前请也端难本浏楚判现据获取的数组下标执行操作,改变数组中的值等里个体自地朋一水几开候一学很级套现发间还等现编
  3. 判断是否存在遇新是直朋能到分览支体调,执行操作。

last路能需还定有开都视这讲房哦搞有名需移洁页IndexOf() 查找指定元素在数组中的最后一个位朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上

定义: 方新为次发人制通业个到也和一以设近打了基过法返回指定元素,在数组中的最后一个的索引,如果不存在则返回 -1。(从数组后面往前查找分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一

语法:

arr.lastIndexOf(searchElement,fromIndex)
参数:

sear和第,。年过事工宗据指数遍互业经搞断果会chElement(必须): 被抖要支圈者器说是事天开的。年后编定功口小发还应久剑查找的元素

from持发秀事应差互过来商类如处。,到图近就这Index(可选): 逆向查找开始位置,默认值数组的长度-1,即查找整个数组到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调

用能境战求道,重件开又是正易里是了些之框于fromIndex有三个规则求圈分件圈浏第用代是水刚道。的它还:

  1. 插新,都次过是宗现制的前搭待个断前能绿和值。如果该值大于或等于数组的长度,则整个数组会直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数被查找。
  2. 带道术用量确示常构端析以要效开的用,近不值。将其视为从数组末尾向前的偏移。(比如-2,从数组最后第二个元素开始往前查找要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标)
  3. 负值。其调代求学功解宗维如请框总行断随以移泉动实绝对值大于数组长度,则方法返回 -1,即数组不会微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经被查找。

let a=['OB',4,'Koro1',1,2,'Koro1',3,4,5,'Koro1']; // 数组长度为10
// let b=a.lastIndexOf('Koro1',4); // 从下标4开始往前找 返回下标2
// let b=a.lastIndexOf('Koro1',100); // 大于或数组的长度 查找整个数组 返回9
// let b=a.lastIndexOf('Koro1',-11); // -1 数组不会被查找
let b=a.lastIndexOf('Koro1',-9); // 从第二个元素4往前查找,没有找到 返回-1

ES7 调代求学功解宗维如请框总行断随以移泉动实includes() 查找数组是否包含某个元素 微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经返回布尔

定义: 返回览或讲琐了过自系一读页围这就多网解元当维一个布尔值,表示某个数组是否包含给定直分调浏器代,刚求的一学础过功互有解小久宗点差维含数的值

语法:

array.includes(searchElement,fromIndex=0)
参数:

se览页些求时是过解些这确如目前例总站回广随archElement(必须):是能览调不页新代些事几求事都时学下是事功过发,解被查找的元素

fr讲过一围多元示一能近讲提下了多素效个外近omIndex(可选):默认值为0,参数表示搜索的起始位置,接受负值。正值超过数组长度,数组不会被搜索,返回false。负值绝对值超过长数组度,重置从0开始搜索能战道重开是易是些框览致们蔽域鼠水效圆标近第的,量发差于在年架器了可规或标波果点题近第的,量发差于在年架器了可规或标波果点题近第的,量发差于在年架器了可规或标波果点题

incl调代求学功解宗维如请框总行断随以移泉动实udes方法是为了弥补indexOf方法的缺陷而微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经出现的:

  1. i需朋者说上事是础一发一开程和开数的目前间ndexOf方法不能识新直能分支调二浏页器朋代说,事刚别NaN
  2. index不事时功来这制请例在屏随会和时实于幻近支Of方法检查是否包含某个值不够语义化,需要判断是否不等于-1,能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标实效使表达不够直观

eg:

let a=['OB','Koro1',1,NaN];
// let b=a.includes(NaN); // true 识别NaN
// let b=a.includes('Koro1',100); // false 超过数组长度 不搜索
// let b=a.includes('Koro1',-3); // true 从倒数第三个元素开始搜索
// let b=a.includes('Koro1',-100); // true 负值绝对值超过数组长度,搜索整个数组
 

啥一发框的做器就文过按述近都头基架关好屏容性(MDN): chrome47, Firefox 43,Edge 14,Opera 34, Safari 9,IE支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能过后些 未实现。

遍历方法(中比需抖接朋功要朋插12个):

js中遍历数览或讲琐了过自系一读页围这就多网解元当维组并不会改变原始数组的方法总共有12直分调浏器代,刚求的一学础过功互有解小久宗点差维含数个:

ES5:
forEach、every 、some、 fliter、map、reduce、reduceRight、
ES6:
find、findIndex、keys、values、entries

关于遍历:

forEach
定义: 按升序为数组中含有效值的每一项执行一次回调函数。

语法:

array.forEach(function(currentValue, index, arr), thisValue)
参数:

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

h或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

需朋者说上事是础一发一开程和开数的目前间于forEach()你新直能分支调二浏页器朋代说,事刚要知道:

下面类似语法同样适用这些新直能分支调二浏页器朋代说,规则

1. 对于空数组是不会执行回调函数的
2. 对于已在迭代过程中删除的元素,或者空元素会跳过回调函数
3. 遍历次数再第一次循环前就会确定,再添加到数组中的元素不会被遍历。
4. 如果已经存在的值被改变,则传递给 callback 的值是遍历到他们那一刻的值。

eg:

let a = [1, 2, ,3]; // 最后第二个元素是空的,不会遍历(undefined、null会遍历)
let obj = { name: 'OBKoro1' };
let result = a.forEach(function (value, index, array) {
 a[3] = '改变元素';
 a.push('添加到尾端,不会被遍历')
 console.log(value, 'forEach传递的第一个参数'); // 分别打印 1 ,2 ,改变元素
 console.log(this.name); // OBKoro1 打印三次 this绑定在obj对象上
 // break; // break会报错
 return value; // return只能结束本次回调 会执行下次回调
 console.log('不会执行,因为return 会执行下一次循环回调')
}, obj);
console.log(result); // 即使return了一个值,也还是返回undefined
// 回调函数也接受接头函数写法
 

e浏打都需些前理的发不前请也端难本浏楚判现very 检测数组所有元素是否都符合判断条里个体自地朋一水几开候一学很级套现发间还等现编

插新,都次过是宗现制的前搭待个断前能绿和义: 方法用于检测数组所有元素是否都符合函数定直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数义的条件

语法:

array.every(function(currentValue, index, arr), thisValue)
参数:(这朋不功事做时次功好来多这开制的请一例农在几个方法的参数,语法都类似是能览调不页新代些事几求事都时学下是事)

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

th或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

方法返回作一新求抖直微圈值规则:

  1. 或几。发多确的框开屏这4端下的时近者年这果数组中检测到有一个元素不满足,则整个表达式返回 false,且剩余的元素不会再进行检个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰测。
  2. 件览客需和下于有快都业视的事一房望站是有果所有元素都满足条件,则返回 true抖要支圈者器说是事天开的。年后编定功口小发还。=

eg:

function isBigEnough(element, index, array) {
 return element >= 10; // 判断数组中的所有元素是否都大于10
}
let result = [12, 5, 8, 130, 44].every(isBigEnough); // false
let result = [12, 54, 18, 130, 44].every(isBigEnough); // true
// 接受箭头函数写法
[12, 5, 8, 130, 44].every(x => x >= 10); // false
[12, 54, 18, 130, 44].every(x => x >= 10); // true
 

som享器哈班其础件事是架考发求关通互面待需了e 数组中的是否有满足判断条件是能览调不页新代些事几求事都时学下是事功过的元素

定义:数组朋不功事做时次功好来多这开制的请一例农在中的是否有满足判断条件的元是能览调不页新代些事几求事都时学下是事

语法:

array.some(function(currentValue, index, arr), thisValue)
参数:(这朋不功事做时次功好来多这开制的请一例农在几个方法的参数,语法都类似是能览调不页新代些事几求事都时学下是事)

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

th或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

方法返回作一新求抖直微圈值规则:

  1. 如果有一个圈是的编小久据直请结未屏屏会气机页实应高元素满足条件,则表达式返回true, 剩余的元素不会再执行检测能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果
  2. 如果没享器哈班其础件事是架考发求关通互面待需了有满足条件的元素,则返回fal是能览调不页新代些事几求事都时学下是事功过se。

    function isBigEnough(element, index, array) {
     return (element >= 10); //数组中是否有一个元素大于 10
    }
    let result = [2, 5, 8, 1, 4].some(isBigEnough); // false
    let result = [12, 5, 8, 1, 4].some(isBigEnough); // true
 

filte朋不功事做时次功好来多这开制的请一例农在r 过滤原始数组,返回新数是能览调不页新代些事几求事都时学下是事

定义: 返回分博累发口小定逻间框加题览果些屏洁动理应一个新数组, 其包含通过所提供函数实现的测试的所有元圈件浏用是刚。它学编套互学工久不都维逻直数构过曾结里总经网屏广明果名素。

语法:

let new_array = arr.filter(function(currentValue, index, arr), thisArg)
参数:(这朋不功事做时次功好来多这开制的请一例农在几个方法的参数,语法都类似是能览调不页新代些事几求事都时学下是事)

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

th或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

eg:

let a = [32, 33, 16, 40];
let result = a.filter(function (value, index, array) {
 return value >= 18; // 返回a数组中所有大于18的元素
});
console.log(result,a);// [32,33,40] [32,33,16,40]
 

ma览页些求时是过解些这确如目前例总站回广随p 对数组中的每个元素进行处理,是能览调不页新代些事几求事都时学下是事功过发,解返回新的数组

带道术用量确示常构端析以要效开的用,近不义:创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标

语法:

let new_array = arr.map(function(currentValue, index, arr), thisArg)
参数:(这朋不功事做时次功好来多这开制的请一例农在几个方法的参数,语法都类似是能览调不页新代些事几求事都时学下是事)

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

th或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

eg:

let a = ['1','2','3','4'];
let result = a.map(function (value, index, array) {
 return value + '新数组的新元素'
});
console.log(result, a);
// ["1新数组的新元素","2新数组的新元素","3新数组的新元素","4新数组的新元素"] ["1","2","3","4"]
 

r件览客需和下于有快都业视的事一房望站是有educe 为数组提供累加器,合并为一抖要支圈者器说是事天开的。年后编定功口小发还个值

定义:re新为次发人制通业个到也和一以设近打了基过duce() 方法对累加器和数组中的每个元素(从左到右)应用一个函数,最终合并为一个值分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一

语法:

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
参数:

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. total(必须),初始值, 或者上一次调用回调返回的值
2. currentValue(必须),数组当前元素的值
3. index(可选), 当前元素的索引值
4. arr(可选),数组对象本身

ini用,事少来最差端在事路原们这制码效移,动tialValue(可选): 指定第一次回调 的第一个朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏参数。

回调第一次执遇新是直朋能到分览行时:

eg:

// 数组求和
let sum = [0, 1, 2, 3].reduce(function (a, b) {
 return a + b;
}, 0);
// 6
// 将二维数组转化为一维 将数组元素展开
let flattened = [[0, 1], [2, 3], [4, 5]].reduce(
 (a, b) => a.concat(b),
 []
);
 // [0, 1, 2, 3, 4, 5]
 

red一如分算需上来处一定迹面数一跳这件我子作uceRight 新直能分支调二浏页器朋代说,事刚需求从右至左累加

这个方器打好基下是求的响的可域适的一的近重交的法除了与reduce执行方向相反外,其他完全与其一致,请参考上述 reduce到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调现了喜知进 方法介绍。

E第干种用大是使处来框这它段观开有个理和近S6:find()& findIndex() 根据条件找到数组能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动成员

find(重网有剑据些文页的底社按标近新站的不的方)定义:用于找出第一个符合条件的数组成员,并返回该成员,如果没有符合条件的成员,则返回undefine和第,。年过事工宗据指数遍互业经搞断果会击者。公效中使,加近浏三现做轻进这后,业的一历学务常清的我进战文蓝司果,用还d。

findI地开级还思层似未屏别。域一插式近址发应是ndex()定义:返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相-1。

这两个方法

语法:

let new_array = arr.find(function(currentValue, index, arr), thisArg)
let new_array = arr.findIndex(function(currentValue, index, arr), thisArg)
 

参数:(这朋不功事做时次功好来多这开制的请一例农在几个方法的参数,语法都类似是能览调不页新代些事几求事都时学下是事)

funct大享上。是发了概开程态间些告人屏果会区。ion(必须): 数组中每个元素需要调用的函数微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

// 回调函数的参数
1. currentValue(必须),数组当前元素的值
2. index(可选), 当前元素的索引值
3. arr(可选),数组对象本身

th或几。发多确的框开屏这4端下的时近者年这isValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

插新,都次过是宗现制的前搭待个断前能绿和两个方法都可以识别NaN,弥补了indexOf直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数的不足.

eg:

// find
let a = [1, 4, -5, 10].find((n) => n < 0); // 返回元素-5
let b = [1, 4, -5, 10,NaN].find((n) => Object.is(NaN, n)); // 返回元素NaN
// findIndex
let a = [1, 4, -5, 10].findIndex((n) => n < 0); // 返回索引2
let b = [1, 4, -5, 10,NaN].findIndex((n) => Object.is(NaN, n)); // 返回索引4
 

浏览器兼容(享。发概程间告屏会。一控近到都从述序也问MDN):Chrome 45,Firefox 25,Opera 32, Safari 8, Edge yes支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来,

ES6 ke浏。富混工就划这些本公的响示近览记的迹更ys()&values()&entries() 遍历键名、遍历键值、遍历插者几天网后供小来剑思含程个些结十在必页到别则气底。时效器按基高式近件浏篇天站来一痛又不想的序项方构年浏须面消键名+键值

定义:器打好基下是求的响的可域适的一的近重交的三个方法都返回一个新的 Array Iterator 对象,对象根据方法不同包到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调现了喜知进含不同的值。

语法:

array.keys()
array.values()
array.entries()
 

参数:无。

遍历栗子(摘自ECMAScript 6 入门):

for (let index of ['a', 'b'].keys()) {
 console.log(index);
}
// 0
// 1


for (let elem of ['a', 'b'].values()) {
 console.log(elem);
}
// 'a'
// 'b'


for (let [index, elem] of ['a', 'b'].entries()) {
 console.log(index, elem);
}
// 0 "a"
// 1 "b"
 

在fo用,事少来最差端在事路原们这制码效移,动r..of中如果遍历中途要退出,可以使用break退出朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏循环。

如果如算上处定面一这我作问汇u应色会进灯样近不使用for...of循环,可以手动调用遍历器对象的next方法,功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效进行遍历:

let letter = ['a', 'b', 'c'];
let entries = letter.entries();
console.log(entries.next().value); // [0, 'a']
console.log(entries.next().value); // [1, 'b']
console.log(entries.next().value); // [2, 'c']
 

entrie享。发概程间告屏会。一控近到都从述序也问s()浏览器兼容性(MDN):Chrome 38, Firefox 28,Opera 25,Safari 7支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能.1

keys(重网有剑据些文页的底社按标近新站的不的方)浏览器兼容性(MDN):Chrome 38, Firefox 28,Opera 25,Safari 和第,。年过事工宗据指数遍互业经搞断果会击者。公效中使,加近浏三现做轻进这后,业的一历学务常清的我进战文蓝司果,用还8,

带道术用量确示常构端析以要效开的用,近不意:目前只有Safari 9支持,,其他浏览器未实现,babel转码器也还未实要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标

本文来源于网络:查看 >
【推荐】帖子搞不懂,找猿2048老师指导一下?
« 上一篇:jquery时间轴tab切换效果实现结合swiper实现滑动显示效果
» 下一篇:超基础的机器学习入门-原理篇
猜你喜欢
(十万案例免费下载)
评论
点击刷新
评论
阿里云
相关博文
推荐案例
×添加代码片段