1. 首页
  2. IT资讯

JavaScript Array 数组使用方法大全( 含ES6 ),值得收藏

“u003Cdivu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002Fc151f3653c3c4bcf97d133718d306be3″ img_width=”1200″ img_height=”678″ alt=”JavaScript Array 数组使用方法大全( 含ES6 ),值得收藏” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Ch1u003E数组操作方法分类u003Cu002Fh1u003Eu003Cpu003E因为数组操作的方法有很多,我们在实际项目中又会经常使用。下面是我自己针对这些方法做的简单分类,请看下表:u003Cu002Fpu003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002Fd3623742f4144ad78c0a9a37ae3efe59″ img_width=”2092″ img_height=”556″ alt=”JavaScript Array 数组使用方法大全( 含ES6 ),值得收藏” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Ch1u003Epush()u003Cu002Fh1u003Eu003Cpu003Epush()可以将某些值加入到数组的最后一个位置,不限制添加数量,欲添加多项内容使用逗号隔开即可,加入后数组长度会增加。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用push()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.push(9, 10);u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Epop()u003Cu002Fh1u003Eu003Cpu003Epop()会移除数组的最后一个元素。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用pop()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.pop();u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 6, 7]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Eshift()、unshift()u003Cu002Fh1u003Eu003Cpu003Eshift()会移除数组的第一个元素。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用shift()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.shift();u003Cbru003Econsole.log(a); u002Fu002F [2, 3, 4, 5, 6, 7, 8]u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003Eunshift()会将指定的元素添加到第一个位置。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用unshift()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.unshift(100,200,300);u003Cbru003Econsole.log(a); u002Fu002F [100, 200, 300, 1, 2, 3, 4, 5, 6, 7, 8]u003Cbru003Ereverse()u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Ereverse()u003Cu002Fh1u003Eu003Cpu003Ereverse()会将数组反转u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用reverse()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.reverse();u003Cbru003Econsole.log(a); u002Fu002F [8, 7, 6, 5, 4, 3, 2, 1]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Esplice()u003Cu002Fh1u003Eu003Cpu003Esplice()可以移除或新增数列的元素,它包含了三个参数,第一个是要移除或要添加的序列号( 必填),第二个是要移除的长度( 选填,若不填则第一个号码位置后方的所有元素都会被移除,若设定为0 则不会有元素被移除),第三个是要替换的内容( 选填 )u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用splice()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.splice(5,1);u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 7, 8] ( 6 被移除了 )u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E设定第三个参数就能够添加或取代元素。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.splice(5,1,100);u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 100, 7, 8] ( 6 被移除,100 加到第 5个位置 )u003Cbru003Elet b = [1,2,3,4,5,6,7,8];u003Cbru003Eb.splice(5,3,100,200,300);u003Cbru003Econsole.log(b); u002Fu002F [1, 2, 3, 4, 5, 100, 200, 300] ( 6,7,8 被移除,100,200,300 加到第 5,6,7 个位置 )u003Cbru003Elet c = [1,2,3,4,5,6,7,8];u003Cbru003Ec.splice(5,0,100);u003Cbru003Econsole.log(c); u002Fu002F [1, 2, 3, 4, 5, 100, 6, 7, 8] ( 沒有元素被移除,100 加到第 5 个位置 )u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Esort()u003Cu002Fh1u003Eu003Cpu003Esort()可以针对数组的元素进行排序,里头包含了一个排序用的判断函数,函式内必须包含两个参数,这两个参数分别代表数组里的第n个和第n+1 个元素,透过比较第n和第n+1个元素的大小来进行排序。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用sort()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,3,8,4,5,7,6,2];u003Cbru003Ea.sort((x,y) => y – x);u003Cbru003Econsole.log(a); u002Fu002F [8, 7, 6, 5, 4, 3, 2, 1]u003Cbru003Ea.sort((x,y) => x – y);u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 6, 7, 8]u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E如果不使用判断函数,预设会将元素转换成字串,并采用unicode来判断,这也会造成某些数字的排序错误,如下段示例:u003Cu002Fpu003Eu003Cpreu003Elet a = [1,3,8,4,5,7,6,2,9,10,11];u003Cbru003Ea.sort();u003Cbru003Econsole.log(a); u002Fu002F [1, 10, 11, 2, 3, 4, 5, 6, 7, 8, 9]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EcopyWithin()u003Cu002Fh1u003Eu003Cpu003EcopyWithin()能复制数组中的某些元素,并将它们放到并取同一个数组指定的位置,copyWithin()有三个参数,第一个是要置换的位置(必填),第二个是从什么位置开始复制(选填,预设0 ),第三个是停止复制的元素的前一个位置(选填,预设等于数组长度)。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用copyWithin()后会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.copyWithin(2);u003Cbru003Econsole.log(a); u002Fu002F [1,2,1,2,3,4,5,6] ( 因 7 和 8 超过数组长度,只出只复制到6 )u003Cbru003Elet b = [1,2,3,4,5,6,7,8];u003Cbru003Eb.copyWithin(3,1,3);u003Cbru003Econsole.log(b); u002Fu002F [1,2,3,2,3,6,7,8] ( 复制 2,3 取代 4,5 )u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Efill()u003Cu002Fh1u003Eu003Cpu003Efill()会把数组中所有元素,置换为指定的值,fill()有三个参数,第一个是准备要置换的内容(必填),第二个是从什么位置开始置换(选填,不设定就全部置换) ,第三个是停止置换的元素的前一个位置(选填,预设等于数组长度)。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E使用fill()会改变原本的数组内容。u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Ea.fill(‘a’);u003Cbru003Econsole.log(a); u002Fu002F [‘a’,’a’,’a’,’a’,’a’,’a’,’a’,’a’]u003Cbru003Elet b = [1,2,3,4,5,6,7,8];u003Cbru003Eb.fill(‘b’,3,5);u003Cbru003Econsole.log(b); u002Fu002F [1,2,3,’b’,’b’,6,7,8]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Elength()u003Cu002Fh1u003Eu003Cpu003Elength可以取得数组的长度( 所有元素的数量)。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.length); u002Fu002F 8u003Cbru003EindexOf()、lastIndexOf()u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003EindexOf()会判断数组中是否包含某个值,判断的方式为「由左而右」,如果有包含就回传这个值在数组中的索引值,如果没有就回传-1,有两个参数,第一个参数表示要判断的值( 必填),第二个参数表示从数组的哪个位置开始判断( 选填,预设为0 )。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.indexOf(4)); u002Fu002F 3u003Cbru003Econsole.log(a.indexOf(4,5)); u002Fu002F -1 ( 在5,6,7,8中搜索有沒有4 )u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003ElastIndexOf()会判断数组中是否包含某个值,判断的方式为「由右而左」,如果有包含就回传这个值在数组中的索引值,如果没有就回传-1,有两个参数,第一个参数表示要判断的值( 必填),第二个参数表示判断到数组的哪个位置( 选填,预设为整个数组长度- 1 )。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.lastIndexOf(3)); u002Fu002F 2u003Cbru003Econsole.log(a.lastIndexOf(3,1)); u002Fu002F -1 ( 只在1,2中判断,所以沒有 3 )u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Efind()u003Cu002Fh1u003Eu003Cpu003Efind()会将数组中的「每一个」元素带入指定的函数内做判断,并会返回第一个符合判断条件的元素,如果没有元素符合则会返回undefined。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.find(e => e > 3)); u002Fu002F 4u003Cbru003Econsole.log(a.find(e => e < 0)); u002Fu002F undefinedu003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EfindIndex()u003Cu002Fh1u003Eu003Cpu003EfindIndex()会将数组中的「每一个」元素带入指定的函数内做判断,并会返回第一个符合判断条件元素的位置序号,如果没有元素符合则会返回-1。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.findIndex(e => e > 3)); u002Fu002F 3u003Cbru003Econsole.log(a.findIndex(e => e < 0)); u002Fu002F -1u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Efilter()u003Cu002Fh1u003Eu003Cpu003Efilter()会将数组中的「每一个」元素带入指定的函数内做判断,如果元素符合判断条件则会返回,组成一个新的数组。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.filter(e => e > 3)); u002Fu002F [4, 5, 6, 7, 8]u003Cbru003Econsole.log(a.filter(e => e%2 == 0)); u002Fu002F [2, 4, 6, 8]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EforEach()u003Cu002Fh1u003Eu003Cpu003EforEach()会将数组中每个元素套用到指定的函数里进行运算,函数有三个参数,第一个参数表示每个元素的值( 必填),第二个参数为该元素的索引值( 选填),第三个参数则表示原本的数组( 选填)。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5];u003Cbru003Elet b = 0;u003Cbru003Ea.forEach(item => {u003Cbru003E b = b + item;u003Cbru003E});u003Cbru003Econsole.log(b); u002Fu002F 15 ( 1+2+3+4+5 )u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E如果结合第二和第三个参数进行搭配使用,就能做到改变原本数组的效果。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5];u003Cbru003Ea.forEach((item, index, arr) => {u003Cbru003E arr[index] = item * 10;u003Cbru003E});u003Cbru003Econsole.log(a); u002Fu002F [10,20,30,40,50]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Ejoin()u003Cu002Fh1u003Eu003Cpu003Ejoin()可以将数组中所有元素,变成由指定的字符分割合并在一起组合成字符串进行呈现,若没有指定字符预设会用「逗号」合并。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.join()); u002Fu002F 1,2,3,4,5,6,7,8u003Cbru003Econsole.log(a.join(”)); u002Fu002F 12345678u003Cbru003Econsole.log(a.join(‘@@’)); u002Fu002F 1@@2@@3@@4@@5@@6@@7@@8u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Econcat()u003Cu002Fh1u003Eu003Cpu003Econcat()可以将两个数组合并在一起,如果是使用ES6语法也可以用扩展运算符…来代替。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5];u003Cbru003Elet b = [6,7,8,9];u003Cbru003Elet c = a.concat(b);u003Cbru003Elet d = […a, …b]; u002Fu002F 使用 …u003Cbru003Econsole.log(c); u002Fu002F [1,2,3,4,5,6,7,8,9]u003Cbru003Econsole.log(d); u002Fu002F [1,2,3,4,5,6,7,8,9]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Eslice()u003Cu002Fh1u003Eu003Cpu003Eslice()可以截取出数组某部份的元素为一个新的数组,有两个必填的参数,第一个是起始位置,第二个是结束位置( 操作时数字减1 )。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.slice(2,4);u003Cbru003Econsole.log(b); u002Fu002F [3, 4]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Emap()u003Cu002Fh1u003Eu003Cpu003Emap()会处理数组中每个元素,最后返回出一个新的数组,里头有一个函数( 必填) 和一个返回函数里的this参数( 选填),函数内又包含三个参数,第一个是每个元素的值( 必填),第二个是当前元素的索引值( 选填),第三个是当前的数组( 选填)。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.map(e => {u003Cbru003E return e + 10;u003Cbru003E});u003Cbru003Econsole.log(b); u002Fu002F [11, 12, 13, 14, 15, 16, 17, 18]u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E使用第二个和第三个参数的示例u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.map((e,i,arr) => {u003Cbru003E return `${e}${i}${arr.find(e => e%5 == 1)}`; u003Cbru003Eu002Fu002F 组合成「元素 + 索引值 + 除以五余数为1的第一个元素」u003Cbru003E});u003Cbru003Econsole.log(b); u002Fu002F [‘101’, ‘211’, ‘321’, ‘431’, ‘541’, ‘651’, ‘761’, ‘871’]u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E如果要使用回传函数里this的参数,则「不能使用」箭头函数,因为箭头函数的this指向和函数的this指向不同,所以要用一般的函数处理。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.map(function(e){u003Cbru003E return e + this; u002Fu002F 此处的 this为10u003Cbru003E}, 10);u003Cbru003Econsole.log(b); u002Fu002F [11, 12, 13, 14, 15, 16, 17, 18]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Ereduce()、reduceRight()u003Cu002Fh1u003Eu003Cpu003Ereduce()可以将数组中每个元素进行计算,每次计算的结果会再与下个元素作计算,直到结束为止,里头包含一个函数( 必填) 和初始计算的数值( 选填),函数内有四个参数,第一个是计算的值( 必填),第二个是取得的元素( 必填),第三个是该元素的索引值( 选填),第四个是原本的数列( 选填)。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.reduce(function(total, e){u003Cbru003E return total + e;u003Cbru003E});u003Cbru003Econsole.log(b); u002Fu002F 36 ( 1+2+3+4+5+6+7+8=36 )u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003EreduceRight()和reduce()大同小异,只是其计算方式是由右到左,对于加法来说没什么影响,但对于减法而言就有差异。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.reduce(function(total, e){u003Cbru003E return total – e; u003Cbru003E});u003Cbru003Econsole.log(b); u002Fu002F -34 ( 1-2-3-4-5-6-7-8 = -34 )u003Cbru003Elet c = a.reduceRight(function(total, e){u003Cbru003E return total – e;u003Cbru003E});u003Cbru003Econsole.log(c); u002Fu002F -20 ( 8-7-6-5-4-3-2-1 = -20 )u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Eflat()u003Cu002Fh1u003Eu003Cpu003Eflat()可以将一个多维数组的深度转成一维(扁平化或称作降维),它有一个选填的参数,代表要转换的深度数字,预设为1(只展开一层放到一维数组里,如果是2,只展开2层放到一位数组里),如果深度有很多层,可使用Infinity来全部展开成一维数组。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,[3],[4,[5,[6]]]];u003Cbru003Elet b = a.flat();u003Cbru003Elet c = a.flat(2);u003Cbru003Elet d = a.flat(Infinity);u003Cbru003Econsole.log(b); u002Fu002F [1, 2, 3, 4, [5, [6]]]u003Cbru003Econsole.log(c); u002Fu002F [1, 2, 3, 4, 5, [6]]u003Cbru003Econsole.log(d); u002Fu002F [1, 2, 3, 4, 5, 6]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EflatMap()u003Cu002Fh1u003Eu003Cpu003EflatMap()的方法等于map()和flat()的组合,在运算后直接将数组扁平化处理。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,[3],[4,5]];u003Cbru003Elet b = a.flatMap(e => e+1);u003Cbru003Elet c = a.map(e => e+1).flat();u003Cbru003Econsole.log(b); u002Fu002F [2, 3, “31”, “4,51”] ( 可以看到 b 和 c 得到的结果相同 )u003Cbru003Econsole.log(c); u002Fu002F [2, 3, “31”, “4,51”]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EArray.isArray()u003Cu002Fh1u003Eu003Cpu003EArray.isArray()能判断一个元素是否为数组,如果是就返回true,不然就返回false。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = 123;u003Cbru003Elet c = ‘hello’;u003Cbru003Elet d = {d1:1,d2:2};u003Cbru003Econsole.log(Array.isArray(a)); u002Fu002F trueu003Cbru003Econsole.log(Array.isArray(b)); u002Fu002F falseu003Cbru003Econsole.log(Array.isArray(c)); u002Fu002F falseu003Cbru003Econsole.log(Array.isArray(d)); u002Fu002F falseu003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EArray.from()u003Cu002Fh1u003Eu003Cpu003EArray.from()会将「类数组」或是「可迭代的对象」转换成数组,Array.from()有两个参数,第一个参数为「类数组对象」或「可迭代的对象」(必填),第二个参数则是改变转换成数组元素的函数(选填)。u003Cu002Fpu003Eu003Cblockquoteu003Eu003Cpu003E类数组对象具有length 属性以及索引化index 的元素,可迭代对象表示具有可以利用迭代的方式取得它自己本身的元素,例如Map 和Set…等。( 参考MDN 说法 )u003Cu002Fpu003Eu003Cu002Fblockquoteu003Eu003Cpreu003Elet a = ‘abcde’;u003Cbru003Elet b = Array.from(a);u003Cbru003Econsole.log(b); u002Fu002F [‘a’,’b’,’c’,’d’,’e’]u003Cbru003Elet c = Array.from(a, e => e + e);u003Cbru003Econsole.log(c); u002Fu002F [‘aa’,’bb’,’cc’,’dd’,’ee’]u003Cbru003Eu003Cu002Fpreu003Eu003Cpu003E类数组对象写法必须包含length 属性,且对象的key须为0开始的数字,对应转换后的元素索引。u003Cu002Fpu003Eu003Cpreu003Elet a = {u003Cbru003E ‘0’: 14, u003Cbru003E ‘2’: 13,u003Cbru003E ‘1’: 7,u003Cbru003E ‘3’: 9,u003Cbru003E ‘4’: 6,u003Cbru003E length: 5u003Cbru003E};u003Cbru003Elet b = Array.from(a);u003Cbru003Econsole.log(b); u002Fu002F [14,7,13,9,6]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EArray.of()u003Cu002Fh1u003Eu003Cpu003EArray.of()可以快速将数字、字串等内容,转换成数组。u003Cu002Fpu003Eu003Cpreu003Elet a = Array.of(1,’a’,2,’b’,3);u003Cbru003Econsole.log(a); u002Fu002F [1, “a”, 2, “b”, 3]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EtoString()u003Cu002Fh1u003Eu003Cpu003EtoString()会把整个数组转换成字符串。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.toString();u003Cbru003Econsole.log(b); u002Fu002F 1,2,3,4,5,6,7,8u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Eevery()u003Cu002Fh1u003Eu003Cpu003Eevery()会将数组中的「每一个」元素带入指定的函数内做判断,只要有任何一个元素不符合判断条件,会回返回false,如果全部符合,就会回传true。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6];u003Cbru003Econsole.log(a.every(e => e > 3)); u002Fu002F fasle ( 因为1、2 小于 3,3 等于 3 )u003Cbru003Econsole.log(a.every(e => e > 0)); u002Fu002F trueu003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Esome()u003Cu002Fh1u003Eu003Cpu003Esome()会将数组中的「每一个」元素带入指定的函数内做判断,只要有任何一个元素符合判断条件,就会返回true,如果全都不符合,才会返回false。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6];u003Cbru003Econsole.log(a.some(e => e > 3)); u002Fu002F 返回 true,因为 4、5、6 大于 3u003Cbru003Econsole.log(a.some(e => e > 6)); u002Fu002F 返回 fasle,因为全都小于或等于 6u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Eincludes()u003Cu002Fh1u003Eu003Cpu003Eincludes()会判断数组中是否包含某个值,如果有包含就返回true,否则返回false,有两个参数,第一个参数表示要判断的值( 必填),第二个参数表示从数组的哪个位置开始判断( 选填)。u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Econsole.log(a.includes(2)); u002Fu002F trueu003Cbru003Econsole.log(a.includes(2,2)); u002Fu002F false ( 在 3,4,5,6,7,8 查找有没有 2 )u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003EvalueOf()u003Cu002Fh1u003Eu003Cpu003EvalueOf()会返回数组的原始值,如果原本的数组有修改,那么返回的原始值也会跟着改变(相当浅复制)u003Cu002Fpu003Eu003Cpreu003Elet a = [1,2,3,4,5,6,7,8];u003Cbru003Elet b = a.valueOf();u003Cbru003Econsole.log(a); u002Fu002F [1, 2, 3, 4, 5, 6, 7, 8]u003Cbru003Elet c = a.valueOf();u003Cbru003Ea.shift();u003Cbru003Econsole.log(a); u002Fu002F [2, 3, 4, 5, 6, 7, 8]u003Cbru003Econsole.log(b); u002Fu002F [2, 3, 4, 5, 6, 7, 8] ( 因为 a 的原始值更新了,所以 b 也变了 )u003Cbru003Econsole.log(c); u002Fu002F [2, 3, 4, 5, 6, 7, 8]u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003Ekeys()u003Cu002Fh1u003Eu003Cpu003Ekeys()会返回数组中的每一个索引值( key )成为一个新的Array Iterator对象,因为是Array Iterator对象,可以使用for…of进行迭代。u003Cu002Fpu003Eu003Cpreu003Elet a = [‘a’,’b’,’c’,’d’,’e’];u003Cbru003Elet b = a.keys(); u003Cbru003Efor (let key of b) {u003Cbru003E console.log(key); u002Fu002F 1、2、3、4、5u003Cbru003E}u003Cbru003Eu003Cu002Fpreu003Eu003Ch1u003E小节u003Cu002Fh1u003Eu003Cdiv class=”pgc-img”u003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fdfic-imagehandleru002Fb050d863-7ea0-481a-be51-45d0c30f16f1″ img_width=”1200″ img_height=”800″ alt=”JavaScript Array 数组使用方法大全( 含ES6 ),值得收藏” inline=”0″u003Eu003Cp class=”pgc-img-caption”u003Eu003Cu002Fpu003Eu003Cu002Fdivu003Eu003Cpu003E今天的总结就到这里,希望能在日常工作中能帮助到您,如果你喜欢本文,建议收藏本文,分享给更多的人看到。u003Cu002Fpu003Eu003Cpu003E更多精彩内容,请u003Cstrongu003E关注“前端达人”公众号u003Cu002Fstrongu003Eu003Cu002Fpu003Eu003Cu002Fdivu003E”

原文始发于:JavaScript Array 数组使用方法大全( 含ES6 ),值得收藏

主题测试文章,只做测试使用。发布者:杀手梦三刀,转转请注明出处:http://www.cxybcw.com/10734.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code