什么是数组

数组是值的有序集合。每个值叫做元素,每个元素在数组中都有数字位置编号,也就是索引。JS中的数组是弱类型的,数组中可以含有不同类型的元素。数组元素甚至可以是对象或其它数组。数组的长度是动态的。可以执行增删改查等操作。

数组的原型是Array.prototype

创建数组

1、字面量创建

var arr = [];

2、构造器创建

var arr  = new Array();

数组的操作

一、添加元素

1、通过索引添加

var arr = [];
arr[0] = 0;
arr[1] = 1;
arr; //[0,1]

2、通过长度添加

length 属性可设置或返回数组中元素的数目。

var arr = [0,1];
arr[arr.length] = 2; //数组的length属性的值是数组最后一个元素的下一个元素所在位置的索引。
arr; //[0,1,2]

3、通过push方法向数组的末尾添加一个或多个元素

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

var arr = [0,1,2];
arr.push(3); //添加一个元素
arr; //[0,1,2,3]
arr.push(4,5); //添加多个元素
arr; //[0,1,2,3,4,5]

4、通过unshift方法向数组的开头添加一个或多个元素

unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。

var arr = [0,1,2,3,4,5];
arr.unshift(-1); //添加一个元素
arr; //[-1,0,1,2,3]
arr.unshift(-3,-2); //添加多个元素
arr; //[-3,-2,-1,0,1,2,3,4,5]

二、删除元素

1、delete删除

var arr = [0,1,2,3];
delete arr[1];
arr; //[0,undefined,2,3]
arr.length; //3

上述例子需要注意的是,通过delete删除后,输出arr.length得到的数组长度仍然为3,因为undefined会占位。

下面使用in操作符来查看刚才删除的元素所在的索引值,结果会返回false

1 in arr;    //false

如果把undefined添加到上述例子中索引值为1的位置后,再用in操作符来查看的话,结果就会返回true

arr[1] = undefined;
1 in arr; //true

2、通过数组长度自建议的方式删除最后一个元素

var arr = [0,1,2];
arr.length -= 1;
arr; //[0, 1]

3、通过pop方法删除数组的最后一个元素

pop() 方法用于删除并返回数组的最后一个元素。

var arr = [0,1,2];
arr.pop();
arr;

4、通过shift方法删除数组的第一个元素

shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。

var arr = [0,1,2];
arr.shift();
arr //[1,2]

数组增删

三、数组的遍历与枚举

1、使用for循环来遍历数组

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

2、使用for in来枚举数组

var i = 0;
var arr = [0,1,2,3,4,5];
for(i in arr){
console.log(arr[i]); //0,1,2,3,4,5
}

数组也是对象,也有原型,如果把数组对象的原型添加一个属性为x并且赋值,然后在通过for in来枚举arr数组,看下会返回什么。

var i = 0;
var arr = [0,1,2,3,4,5];
Array.prototype.x = 'last';
for(i in arr){
console.log(arr[i]); //0,1,2,3,4,5,last
}

运行上述例子后,返回0,1,2,3,4,5,last;这是因为for in会把原型上的属性也给枚举出来;如果不想枚举原型上的属性,可以通过hasOwnProperty来判断下,把原型上的属性过滤掉;

for(i in arr){
if(arr.hasOwnProperty(i)){
console.log(arr[i]); //0,1,2,3,4,5
}
}

对象是否可枚举

四、数组转字符串

数组转字符串是通过join方法操作的

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

var arr = [1,2,3,4,5];
var str = arr.join(); //不加分隔符的,默认为分隔符为‘,’;
console.log(str); //1,2,3,4,5
var str = arr.join('|'); //自定义分隔符的
console.log(str); //1|2|3|4|5

数组转字符串

五、数组序列化

1、逆序

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

var arr = [1,2,3,4,5];
arr.reverse();
arr; //[5, 4, 3, 2, 1]

2、数组排序

sort() 方法用于对数组的元素进行排序。

sort() 方法会改写原数组。

//例子1:
var arr = [1,4,3,2,5];
arr.sort();
arr; //[1, 2, 3, 4, 5] //例子2:
var arr=[4,26,51,30,15];
arr.sort();
arr; //[15, 26, 30, 4, 51];注:此处并没有按照数字的大小去排序,而是先把数组转换为字符串,然后按照数字的个位数进行排序;

若想将上述例子2中的数字按照大小排序的话,则需要使用排序函数

var arr=[4,26,51,30,15];
arr.sort(function(x,y){
return x - y; //正序
}) //[4, 15, 26, 30, 51] arr.sort(function(x,y){
return x - y; //倒序
}) //[51, 30, 26, 15, 4] arr.sort(function(x,y){
return y = x; //正序
}) //[4, 15, 26, 30, 51] arr.sort(function(x,y){
return x = y; //倒序
}) //[51, 30, 26, 15, 4]

数组排序

六、 数组合并

concat() 方法用于连接两个或多个数组。

该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。

//例子1:
var arr = [1,2,3,4,5];
arr.concat(6,7,8,9,0); //[1, 2, 3, 4, 5, 6, 7, 8, 9, 0] //例子2:
var arr = [1,2,3,4,5];
arr.concat(6,7,8,[9,0]); //[1, 2, 3, 4, 5, 6, 7, 8, 9, 0] 注:这里以数组作为参数的话,输出时数组会被拉平。 //例子3:
var arr = [1,2,3,4,5];
arr.concat([6,7,8,[9,0]]); //[1, 2, 3, 4, 5, 6, 7, 8, [9, 0]] 注:若数组的元素还是数组,则不会拉平两次。

七、返回数组中的部分元素

slice() 方法可从已有的数组中返回选定的元素。slice() 方法不会修改原数组

该方法有两个参数

start:必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。

end:可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

上面的定义理解起来或许会有点绕,我理解的end就是想要返回的结尾元素的下一个位置;

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

如上代码展示的是想要返回从下标为0的元素开始到下标为2的元素结束的这部分数组元素,那么end就传入元素下标为2的下一个元素的下标;

下面举例参数为负值的情况;

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

八、数组拼接

splice() 方法向/从数组中添加/删除项目,然后以数组的形式返回被删除的项目。

splice() 方法会改变原始数组。

var arr = [1,2,3,4,5];
arr.splice(1,2); //[2, 3]
arr; //[1, 4, 5] var arr = [1,2,3,4,5];
arr.splice(2); //[3, 4, 5]
arr; //[1, 2] var arr = [1,2,3,4,5];
arr.splice(0,2,"a","b"); //[1, 2]
arr; //["a", "b", 3, 4, 5]

数组拼接

ES5中数组原型对象的属性

一、forEach方法。

Array.prototype.forEach ( callbackfn [ , thisArg ] )

callbackfn 有三个参数,第一个是遍历的数组元素的值,第二个是对应数组元素的索引,第三个是数组本身。

thisArg 参数, 它会被当作 this 值传给每个 callbackfn 调用。如果没提供它,用 undefined 替代。

forEach 方法的 length 属性是 1。

forEach方法是用来循环遍历数组的,可以替代for、for in。

var arr = [1,2,3,4,5];
arr.forEach(function(v,i,a){
console.log(v+'|-|'+i+'|-|'+a);
})
//1|-|0|-|1,2,3,4,5
//2|-|1|-|1,2,3,4,5
//3|-|2|-|1,2,3,4,5
//4|-|3|-|1,2,3,4,5
//5|-|4|-|1,2,3,4,5 arr.forEach(function(v,i,a){
console.log(v+'|-|'+i+'|-|'+a);
console.log(this.test);
},{test:'test'})
//1|-|0|-|1,2,3,4,5
//test
//2|-|1|-|1,2,3,4,5
//test
//3|-|2|-|1,2,3,4,5
//test
//4|-|3|-|1,2,3,4,5
//test
//5|-|4|-|1,2,3,4,5
//test

二、map方法

Array.prototype.map ( callbackfn [ , thisArg ] )

callbackfn 有三个参数,第一个是遍历的数组元素的值,第二个是对应数组元素的索引,第三个是数组本身。

thisArg 参数, 它会被当作 this 值传给每个 callbackfn 调用。如果没提供它,用 undefined 替代。

map方法的 length 属性是 1。

map方法主要是对数组做一些映射。可以对数组内的元素进行操作。

var arr = [1,2,3,4,5];
arr.map(function(v){
return v*10
}) //[10, 20, 30, 40, 50]

三、filter方法

Array.prototype.filter ( callbackfn [ , thisArg ] )

callbackfn 有三个参数,第一个是遍历的数组元素的值,第二个是对应数组元素的索引,第三个是数组本身。

thisArg 参数, 它会被当作 this 值传给每个 callbackfn 调用。如果没提供它,用 undefined 替代。

filter方法的 length 属性是 1。

filter方法可以根据逻辑运算符筛选出想要返回的数组元素。

var arr = [1,2,3,4,5];
arr.filter(function(v,x,a){
return v === 4||x===4
}) //[4, 5]

四、数组判断:every()和some()

1、every()

Array.prototype.every ( callbackfn [ , thisArg ] )

callbackfn 有三个参数,第一个是遍历的数组元素的值,第二个是对应数组元素的索引,第三个是数组本身。

thisArg 参数, 它会被当作 this 值传给每个 callbackfn 调用。如果没提供它,用 undefined 替代。

every 方法的 length 属性是 1。

every方法会遍历数组中的每一个元素是否都满足callbackfn中的逻辑

var arr = [1,2,3,4,5];
arr.every(function(x){
return x < 10;
}) //true arr.every(function(x){
return x < 3;
}) //false

2、some()

Array.prototype.some ( callbackfn [ , thisArg ] )

callbackfn 有三个参数,第一个是遍历的数组元素的值,第二个是对应数组元素的索引,第三个是数组本身。

thisArg 参数, 它会被当作 this 值传给每个 callbackfn 调用。如果没提供它,用 undefined 替代。

some 方法的 length 属性是 1。

some方法只要数组中有任意一个元素满足callbackfn中的逻辑,就会返回true

var arr = [1,2,3,4,5];
arr.some(function(x){
return x === 2;
}) //true var arr = [1,2,3,4,5];
arr.some(function(x){
return x === 6;
}) //false

五、reduce方法和reduceRight方法

1、reduce方法

Array.prototype.reduce ( callbackfn [ , initialValue ] )

调用 callbackfn 时将传入四个参数:previousValue(initialValue 的值或上次调用 callbackfn 的返回值),currentValue(当前元素值),currentIndex,和遍历的对象。第一次调用回调函数时,previousValue 和 currentValue 的取值可以是下面两种情况之一。如果为 reduce 调用提供了一个 initialValue,则 previousValue 将等于 initialValue 并且 currentValue 将等于数组的首个元素值。如果没提供 initialValue,则 previousValue 将等于数组的首个元素值并且 currentValue 将等于数组的第二个元素值。如果数组里没有元素并且没有提供 initialValue,则抛出一个 TypeError 异常。

reduce 方法是从左到右对数组遍历的。

reduce 方法可以根据运算符等方式来对数组的元素进行两两的操作。

var arr = [1,2,3,4,5];
arr.reduce(function(x,y){
return x+y
}) //15

上面例子的算法是先拿数组的第一个元素和第二个元素相加,然后在拿它们相加后得到的值作为第一个元素和后面没有进行相加的操作的第一个元素相加,以此类推。也就是1加2等于3,3加3等于6,6加4等于10,10加5等于15;

reduce方法根据逻辑运算符例子:

var arr = [1,3,5,7,9];
arr.reduce(function(x,y){
console.log(x+'<'+y);
return x > y ? x : y;
})
//1<3
//3<5
//5<7
//7<9
//9

2、reduceRight方法

Array.prototype.reduceRight ( callbackfn [ , initialValue ] );

调用 callbackfn 时将传入四个参数:previousValue(initialValue 的值或上次调用 callbackfn 的返回值),currentValue(当前元素值),currentIndex,和遍历的对象。第一次调用回调函数时,previousValue 和 currentValue 的取值可以是下面两种情况之一。如果为 reduceRight 调用提供了一个 initialValue,则 previousValue 将等于 initialValue 并且 currentValue 将等于数组的最后一个元素值。如果没提供 initialValue,则 previousValue 将等于数组的最后一个元素值并且 currentValue 将等于数组的倒数第二个元素值。如果数组里没有元素并且没有提供 initialValue,则抛出一个 TypeError 异常。

reduceRight方法是从右到左对数组进行遍历

把上述例子换成用reduceRight方法来操作

var arr = [1,2,3,4,5];
arr.reduceRight(function(x,y){
return x+y
}) //15
var arr = [1,3,5,7,9];
arr.reduceRight(function(x,y){
console.log(x+'>'+y);
return x > y ? x : y;
})
//9>7
//9>5
//9>3
//9>1
//9

总结:reduce和reduceRight方法是把整个数组通过各种运算或者逻辑聚合成一个结果。

六、数组检索:indexOf()和lastIndexOf()

1、indexOf()

Array.prototype.indexOf ( searchElement [ , fromIndex ] )

indexOf 按照索引的升序比较 searchElement 和数组里的元素们,它使用内部的严格相等比较算法 (11.9.6),如果找到一个或更多这样的位置,返回这些位置中第一个索引;否则返回 -1。

可选的第二个参数 fromIndex 默认是 0(即搜索整个数组)。如果它大于或等于数组长度,返回 -1,即不会搜索数组。如果它是负的,就把它当作从数组末尾到计算后的 fromIndex 的偏移量。如果计算后的索引小于 0,就搜索整个数组。

indexOf()方法是从左到右检索的

var arr = [1,3,5,3,1];
arr.indexOf(3); //查找元素为3在数组中的索引;返回1
arr.indexOf(3,2); //从索引2开始查找元素为3在数组中的位置;返回3
arr.indexOf(3,1); //从索引1开始查找元素为3在数组中的位置;返回1
arr.indexOf(99); //数组元素中没用99这个元素;返回-1
arr.indexOf(1,-1); //从索引为-1(数组的最后一个元素)开始查找元素为1在数组中的位置;返回4

2、lastIndexOf()

Array.prototype.lastIndexOf ( searchElement [ , fromIndex ] )

lastIndexOf 按照索引的降序比较 searchElement 和数组里的元素们,它使用内部的严格相等比较算法 (11.9.6),如果找到一个或更多这样的位置,返回这些位置中最后一个索引;否则返回 -1。

可选的第二个参数 fromIndex 默认是数组的长度减一(即搜索整个数组)。如果它大于或等于数组长度,将会搜索整个数组。如果它是负的,就把它当作从数组末尾到计算后的 fromIndex 的偏移量。如果计算后的索引小于 0,返回 -1。

lastIndexOf()从右到左检索的

var arr = [1,3,5,3,1];
arr.lastIndexOf(3); //从右往左开始查找元素为3在数组中的位置;返回3
arr.lastIndexOf(3,2); //从索引为2的元素开始从右往左查找元素为3在数组中的位置;返回1
arr.lastIndexOf(1,-2); //从索引为-2的元素开始从右往左查找元素为1在数组中的位置;返回0

Array构造器属性

Array.isArray ( arg )——判断是否为数组

isArray 函数需要一个参数 arg,如果参数是个对象并且 class 内部属性是 "Array", 返回布尔值 true;否则它返回 false。

  • 如果 Type(arg) 不是 Object, 返回 false。
  • 如果 arg 的 [[Class]] 内部属性值是 "Array", 则返回 true。
  • 返回 false.
var arr = [];
Array.isArray(arr); //true

javascript第三弹——数组的更多相关文章

  1. 前端学习 第三弹: JavaScript语言的特性与发展

    前端学习 第三弹: JavaScript语言的特性与发展 javascript的缺点 1.没有命名空间,没有多文件的规范,同名函数相互覆盖 导致js的模块化很差 2.标准库很小 3.null和unde ...

  2. JavaScript数组(三)数组对象使用整理

    一.数组声明方法1. var  a=new Array();2. var a=new Array([size]);3.var a=new Array(['a'],[1],['b'],[123]);4. ...

  3. javascript 转化一个数字数组为function数组(每个function都弹出相应的数字)

    javascript 转化一个数字数组为function数组(每个function都弹出相应的数字) var arrNum = [2,3,4,5,6,10,7]; var arrFun = []; f ...

  4. javaScript(8)---对象和数组

    javaScript(8)---对象和数组 学习要点: 1.Object类型 2.Array类型 3.对象中的方法 什么是对象,其实就是一种类型,即引用类型.而对象的值就是引用类型的实例.在ECMAS ...

  5. Emscripten教程之连接C++和JavaScript(三)

    本文是Emscripten-WebAssembly专栏系列文章之一,更多文章请查看专栏.也可以去作者的博客阅读文章.欢迎加入Wasm和emscripten技术交流群,群聊号码:939206522. E ...

  6. JavaScript 之 对象/JSON/数组

    对象 简单说,所谓对象,就是一种无序的数据集合,由若干个“键值对”(key-value)构成. var obj = { p: 'Hello World' }; 上面代码中,大括号就定义了一个对象,它被 ...

  7. 学习javascript数据结构(三)——集合

    前言 总括: 本文讲解了数据结构中的[集合]概念,并使用javascript实现了集合. 原文博客地址:学习javascript数据结构(三)--集合 知乎专栏&&简书专题:前端进击者 ...

  8. JavaScript jQuery 中定义数组与操作及jquery数组操作

    首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...

  9. JavaScript中常见的数组操作函数及用法

    JavaScript中常见的数组操作函数及用法 昨天写了个帖子,汇总了下常见的JavaScript中的字符串操作函数及用法.今天正好有时间,也去把JavaScript中常见的数组操作函数及用法总结一下 ...

随机推荐

  1. 【云计算】Docker云平台—Docker进阶

    Docker云平台系列共三讲,此为第二讲:Docker进阶 参考资料: 五个Docker监控工具的对比:http://www.open-open.com/lib/view/open1433897177 ...

  2. MySQL报错:Packets larger than max_allowed_packet are not allowed 的解决方案

    在导大容量数据特别是CLOB数据时,可能会出现异常:“Packets larger than max_allowed_packet are not allowed”. 这是由于MySQL数据库有一个系 ...

  3. spring事物传播属性

    PROPAGATION_REQUIRED Support a current transaction; create a new one if none exists.  支持一个当前事务;如果不存在 ...

  4. PHP负数判空

    2014年11月6日 10:08:09 $a = -1; $b = '-1'; $c = empty($a); $d = empty($b); var_dump($c, $d); // bool(fa ...

  5. 写了一个字符串的二维表: TSta

    STA 单元 (用到 System.SysUtils.TStringHelper): --------------------------------------------------------- ...

  6. codeforces 472C.Make It Nondeterministic 解题报告

    题目链接:http://codeforces.com/problemset/problem/472/C 题目意思:给出 n 个 people(从第1行往下数,编号依次为1,2,...,n),每 个 p ...

  7. ext树表+ZeroClipboard复制链接功能

    效果图:

  8. Android仿微信界面

    效果图 原理介绍 1.先绘制一个颜色(例如:粉红) 2.设置Mode=DST_IN 3.绘制我们这个可爱的小机器人 回答我,显示什么,是不是显示交集,交集是什么?交集是我们的小机器人的非透明区域,也就 ...

  9. iOS的I/O操作

    一般而言,处理文件时都要经历以下四个步骤: 1.创建文件 2.打开文件,以便在后面的I/O操作中引用该文件 3.对打开的文件执行I/O操作(读取.写入.更新) 4.关闭文件 iOS中,对文件常见的处理 ...

  10. Guid和Int还有Double、Date的ToString方法的常见格式(转载)

    Guid的常见格式: 1.Guid.NewGuid().ToString("N") 结果为:       38bddf48f43c48588e0d78761eaa1ce6 2.Gu ...