浅谈JavaScript Array对象


Posted in Javascript onDecember 29, 2014

Array 数组

1. 介绍

      数组是值的有序集合。每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引。JavaScript数组是无类型:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的类型。 --《JavaScript权威指南(第六版)》

2. 定义

var names = new Array("张三", "李四", "王五");

//或者

var names = ["张三", "李四", "王五"];

3. 属性

length:表示数组内的元素长度。

4. 实例方法

常用方法:

1) unshift() :在数组头部插入元素

2) shift() :移除并返回数组的第一个元素

3) push() :在数组尾部插入元素

4) pop() :移除并返回数组的最后一个元素

4.1 concat() :把元素衔接到数组中。不会修改原先的array,返回新的数组
参数:

①value1,value2.....valueN :任意多个值

返回值:

{Array} 一个新的数组,包含原先的Array和新加入的元素。

示例:

var demoArray = ['a', 'b', 'c'];

var demoArray2 = demoArray.concat('e');

console.log(demoArray); // => demoArray:['a','b','c']  原数组不发生变更

console.log(demoArray2); // => ['a','b','c','e']

4.2 every() :依次遍历元素,判断每个元素是否都为true
参数:

①function(value,index,self){} :每个元素都会使用此函数判断是否为true,当判断到一个为false时,立即结束遍历。

value :数组遍历的元素

index :元素序号

self :Array本身

返回值:

{Boolean} :只有每个元素都为true才返回true;只要一个为false,就返回false。

示例:

var demoArray = [1, 2, 3];

var rs = demoArray.every(function (value, index, self) {

    return value > 0;

});

console.log(rs); // => true

4.3 filter() :依次遍历元素,返回包含符合条件元素的新的数组。
参数:

①function(value,index,self){} :每个元素依次调用此函数,返回包含符合条件元素的新的数组。

value :数组遍历的元素

index :元素序号

self :Array本身

返回值:

{Array} 一个包含符合条件元素的新的数组

示例:

var demoArray = [1, 2, 3];

var rs = demoArray.filter(function (value, index, self) {

    return value > 0;

});

console.log(rs); // => [1, 2, 3]

4.4 forEach() :依次遍历元素,执行指定的函数;无返回值。
参数:

①function(value,index,self){} :每个元素依次调用此函数

value :数组遍历的元素

index :元素序号

self :Array本身

返回值:无

示例:

var demoArray = [1, 2, 3];

demoArray.forEach(function (value, index, self) {

    console.log(value); // => 依次输出:1  2  3

});

4.5 indexOf() :在数组中查找匹配元素。若不存在匹配的元素时,就返回-1。查找的时候使用"==="运算符,所以要区分1和'1'
参数:

①value :要在数组中查找的值。

②start :开始查找的序号位置,如果省略,则为0.

返回值:

{Int} :返回数组中第一个匹配value的序号,若不存在,返回-1

示例:

['a', 'b', 'c'].indexOf('a'); // =>0

['a', 'b', 'c'].indexOf('a', 1); // =>-1

['a', 'b', 'c'].indexOf('d'); // =>-1

[1, 2, 3].indexOf('1'); // => -1 :采用的'==='匹配方式

4.6 join() :将数组中所有元素通过一个分隔符拼接为一个字符串。
参数:

①sparator {String}:各元素之间的分隔符,如果省略,默认以因为英文逗号','分隔。

返回值:

{String} :各元素以sparator为分隔符,拼接而成的一个字符串。

示例:

['a', 'b', 'c'].join(); // => 'a,b,c'

['a', 'b', 'c'].join('-'); // => 'a-b-c'

4.7 lastIndexOf :在数组中反向查找匹配元素。若不存在匹配的元素时,就返回-1。查找的时候使用"==="运算符,所以要区分1和'1'
参数:

①value :要在数组中查找的值。

②start :开始查找的序号位置,如果省略,则从最后一个元素开始查找。

返回值:

{Int} :从右到左开始查找数组中第一个匹配value的序号,若不存在,返回-1

示例:

['a', 'b', 'c'].lastIndexOf('a'); // => 0

['a', 'b', 'c'].lastIndexOf('a', 1); // => 0

['a', 'b', 'c'].lastIndexOf('d'); // => -1

[1, 2, 3].lastIndexOf('1'); // => -1 :采用的'==='匹配方式

4.8 map() :依次遍历并计算每个元素,返回计算好的元素的数组
参数:

①function(value,index,self){} :每个元素依次调用此函数,返回计算好的元素

value :数组遍历的元素

index :元素序号

self :Array本身

返回值:

{Array} 一个包含就算好的元素的新的数组

示例:

[1, 2, 3].map(function (value, index, self) {

    return value * 2;

}); // => [2, 4, 6]

4.9 pop() :移除并返回数组的最后一个元素
参数:无

返回值:

{Object} 数组的最后一个元素;若数组为空,返回undefined

示例:

var demoArray = ['a', 'b', 'c'];

demoArray.pop(); // => c

demoArray.pop(); // => b

demoArray.pop(); // => a

demoArray.pop(); // => undefined

4.10 push() :把元素添加到数组尾部
参数:

①value1,value2.....valueN :任意多个值添加到数组尾部

返回值:

{int} 数组新的长度

示例:

var demoArray = ['a', 'b', 'c'];

demoArray.push('d'); // => 4, demoArray : ['a', 'b', 'c', 'd']

demoArray.push('e', 'f'); // => 6, demoArray :['a', 'b', 'c', 'd', 'e', 'f']

console.log(demoArray); // => ['a', 'b', 'c', 'd', 'e', 'f']

4.11 reverse() :反转数组元素的顺序。
参数:无

返回值:无(在原数组内进行元素顺序反转)。

示例:

var demoArray = ['a', 'b', 'c', 'd', 'e'];

demoArray.reverse();

console.log(demoArray); // => ["e", "d", "c", "b", "a"]

4.12 shift() :移除并返回数组的第一个元素
参数:无

返回值:

{Object} 数组的第一个元素;若数组为空,返回undefined。

示例:

var demoArray = ['a', 'b', 'c'];

demoArray.shift(); // => a

demoArray.shift(); // => b

demoArray.shift(); // => c

demoArray.shift(); // => undefined

4.13 slice(startIndex,endIndex) :返回数组的一部分。
参数:

①startIndex :开始处的序号;若为负数,表示从尾部开始计算,-1代表最后一个元素,-2倒数第二个,依此类推。

②endIndex : 结束处的元素后一个序号,没指定就是结尾。截取的元素不包含此处序号的元素,结尾为此处序号的前一个元素。

返回值:

{Array} 一个新的数组,包含从startIndex到endIndex前一个元素的所有元素。

示例:

[1, 2, 3, 4, 5, 6].slice(); // => [1, 2, 3, 4, 5, 6]

[1, 2, 3, 4, 5, 6].slice(1); // => [2, 3, 4, 5, 6] :从序号1开始截取

[1, 2, 3, 4, 5, 6].slice(0, 4); // => [1, 2, 3, 4] :截取序号0到序号3(序号4的前一个)的元素

[1, 2, 3, 4, 5, 6].slice(-2); // => [5, 6] :截取后面的2个元素

4.14 sort(opt_orderFunc) :按一定的规则进行排序
参数:

①opt_orderFunc(v1,v2) {Function}:可选的排序规则函数。若省略,将按照元素的字母进行从小到大排序。

v1 :遍历时前面的元素。

v2 :遍历时后面的元素。

排序规则:

比较v1和v2,返回一个数字来表示v1和v2的排序规则:

小于0 :v1小于v2,v1排在v2的前面。

等于0 :v1等于v2,v1排在v2的前面。

大于0 :v1大于v2,v1排在v2的后面。

返回值:无(在原先数组里进行排序操作)。

示例:

[1, 3, 5, 2, 4, 11, 22].sort(); // => [1, 11, 2, 22, 3, 4, 5] :这里都元素都被转换为字符,11的字符在2前

[1, 3, 5, 2, 4, 11, 22].sort(function (v1, v2) {

    return v1 - v2;

}); // => [1, 2, 3, 4, 5, 11, 22] :从小到大排序

[1, 3, 5, 2, 4, 11, 22].sort(function (v1, v2) {

    return -(v1 - v2); //取反,就可以转换为 从大到小

}); // => [22, 11, 5, 4, 3, 2, 1]

4.15 splice() :插入、删除数组元素
参数:

①start {int} :开始插入、删除或替换的起始序号。

②deleteCount {int} :要删除元素的个数,从start处开始计算。

③value1,value2 ... valueN {Object} :可选参数,表示要插入的元素,从start处开始插入。若②参不为0,那么先执行删除操作,再执行插入操作。

返回值:

{Array}  返回一个包含删除元素的新的数组。若②参为0,表示没元素删除,返回一个空数组。

示例:

// 1.删除

var demoArray = ['a', 'b', 'c', 'd', 'e'];

var demoArray2 = demoArray.splice(0, 2); // 删除从序号从0开始的2个元素,返回包含删除元素的数组:['a', 'b']

console.log(demoArray2); // => ['a', 'b']

console.log(demoArray); // => ['c', 'd', 'e']

// 2.插入

var demoArray = ['a', 'b', 'c', 'd', 'e'];

var demoArray2 = demoArray.splice(0, 0, '1', '2', '3'); // ②参为0,返回空数组

console.log(demoArray2); // => [ ]

console.log(demoArray); // => ['1', '2', '3', 'a', 'b', 'c', 'd', 'e']

// 3.先删除再插入

var demoArray = ['a', 'b', 'c', 'd', 'e'];

// 当②参不为0,那么先执行删除操作(删除序号从0开始的4个元素,返回包含被删除元素的数组),再执行插入操作

var demoArray2 = demoArray.splice(0, 4, '1', '2', '3');

console.log(demoArray2); // => ['a', 'b', 'c', 'd'] 

console.log(demoArray); // => ['1', '2', '3', 'a', 'b', 'c', 'd', 'e']

4.16 toString() :将数组中所有元素通过一个英文逗号','拼接为一个字符串。
参数:无

返回值:

{String}  数组中所有元素通过一个英文逗号','拼接为一个字符串,并返回。与调用无参join()方法一样。

示例:

[1, 2, 3, 4, 5].toString(); // => '1,2,3,4,5'

['a', 'b', 'c', 'd', 'e'].toString(); // => 'a,b,c,d,e'

4.17 unshift() :在数组头部插入元素
参数:

①value1,value2.....valueN :任意多个值添加到数组头部

返回值:

{int} 数组新的长度

示例:

var demoArray = [];

demoArray.unshift('a'); // => demoArray:['a']

demoArray.unshift('b'); // => demoArray:['b', 'a']

demoArray.unshift('c'); // => demoArray:['c', 'b', 'a']

demoArray.unshift('d'); // => demoArray:['d', 'c', 'b', 'a']

demoArray.unshift('e'); // => demoArray:['e', 'd', 'c', 'b', 'a']

5. 静态方法

5.1 Array.isArray() :判断对象是否为数组
参数:

①value {Object}:任意对象

返回值:

{Boolean}  返回判断结果。当为 true时,表示对象为数组;为false时,表示对象不是数组

示例:

Array.isArray([]); // => true

Array.isArray(['a', 'b', 'c']); // => true

Array.isArray('a'); // => false

Array.isArray('[1, 2, 3]'); // => false

6. 实际操作

6.1 索引
说明:每个元素在数组中有一个位置,以数字表示,称为索引。索引是从0开始计,即第一个元素的索引为0,第二个元素的索引为1,依此类推;

        当获取一个数组不存在的索引时,返回 undefined。

示例:

var demoArray = ['a', 'b', 'c', 'd', 'e'];

demoArray[0]; // => 获取第一个元素:'a'

demoArray[0] = 1;  // 设置第一个元素为 1

console.log(demoArray); // => demoArray:[1, 'b', 'c', 'd', 'e']

console.log(demoArray[9]); // => undefined :当获取的索引不存在时,返回 undefined

6.2 for 语句
说明:可以通过for语句逐个遍历数组

示例:

var demoArray = ['a', 'b', 'c', 'd', 'e'];

for (var i = 0, length = demoArray.length; i < length; i++) {

    console.log(demoArray[i]); // => 逐个输出数组内的元素

}

6.3 浅度复制
说明:Array类型是一种引用类型;当数组a复制给数组b时,对数组b进行元素修改,数组a也会发生修改。

示例:

var demoArrayA = ['a', 'b', 'c', 'd', 'e'];

var demoArrayB = demoArrayA; // 把数组A 赋值给数组B

demoArrayB[0] = 1; // 对数组B 的元素进行修改

console.log(demoArrayA); // => [1, 'b', 'c', 'd', 'e']:数组A 的元素也发生了变更

6.4 深度复制
说明:使用concat()方法,返回新的数组;防止浅度复制的情况发生,对数组b进行元素修改操作,数组a不发生变更。

示例:

var demoArrayA = ['a', 'b', 'c', 'd', 'e'];

var demoArrayB = demoArrayA.concat(); // 使用concat()方法,返回新的数组

demoArrayB[0] = 1; // 对数组B 的元素进行修改

console.log(demoArrayA); // => ['a', 'b', 'c', 'd', 'e']:数组A 的元素没变更

console.log(demoArrayB); // => [  1, 'b', 'c', 'd', 'e']:数组B 的元素发生了变更
Javascript 相关文章推荐
基于JavaScript实现继承机制之原型链(prototype chaining)的详解
May 07 Javascript
JavaScript中this关键词的使用技巧、工作原理以及注意事项
May 20 Javascript
Jquery图片延迟加载插件jquery.lazyload.js的使用方法
May 21 Javascript
JQuery 控制内容长度超出规定长度显示省略号
May 23 Javascript
javascript实现倒计时跳转页面
Jan 17 Javascript
JS三级可折叠菜单实现方法
Feb 29 Javascript
JS实现百度搜索接口及链接功能实例代码
Feb 02 Javascript
在小程序开发中使用npm的方法
Oct 17 Javascript
JS中超越现实的匿名函数用法实例分析
Jun 21 Javascript
vue实现select下拉显示隐藏功能
Sep 30 Javascript
基于vue-draggable 实现三级拖动排序效果
Jan 10 Javascript
前端vue如何使用高德地图
Nov 05 Javascript
JavaScript实现N皇后问题算法谜题解答
Dec 29 #Javascript
jQuery中dequeue()方法用法实例
Dec 29 #Javascript
jQuery中queue()方法用法实例
Dec 29 #Javascript
浅谈JavaScript function函数种类
Dec 29 #Javascript
JavaScript异步加载浅析
Dec 28 #Javascript
JavaScript设计模式之工厂方法模式介绍
Dec 28 #Javascript
JavaScript设计模式之抽象工厂模式介绍
Dec 28 #Javascript
You might like
Php部分常见问题总结
2006/10/09 PHP
PHP循环遍历数组的3种方法list()、each()和while总结
2014/11/19 PHP
php中Ioc(控制反转)和Di(依赖注入)
2017/05/07 PHP
PHP7.1实现的AES与RSA加密操作示例
2018/06/15 PHP
浅谈PHP进程管理
2019/03/08 PHP
json 定义
2008/06/10 Javascript
JavaScript 动态添加表格行 使用模板、标记
2009/10/24 Javascript
JavaScript 学习笔记(十五)
2010/01/28 Javascript
Javascript学习笔记一 之 数据类型
2010/12/15 Javascript
Jquery命名冲突解决的五种方案分享
2012/03/16 Javascript
js播放wav文件(源码)
2013/04/22 Javascript
Javascript级联下拉菜单以及AJAX数据验证核心代码
2013/05/10 Javascript
原生js实现半透明遮罩层效果具体代码
2013/06/06 Javascript
js操作iframe的一些方法介绍
2013/06/25 Javascript
avalon js实现仿google plus图片多张拖动排序附源码下载
2015/09/24 Javascript
微信公众号开发 自定义菜单跳转页面并获取用户信息实例详解
2016/12/08 Javascript
Angular排序实例详解
2017/06/28 Javascript
vue 封装自定义组件之tabal列表编辑单元格组件实例代码
2017/09/07 Javascript
基于vue 实现token验证的实例代码
2017/12/14 Javascript
EasyUI的DataGrid绑定Json数据源的示例代码
2017/12/16 Javascript
微信小程序支付PHP代码
2018/08/23 Javascript
手把手教你写一个微信小程序(推荐)
2018/10/17 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
2020/05/29 jQuery
微信小程序实现简单购物车功能
2020/12/30 Javascript
[04:15]DOTA2-DPC中国联赛 正赛 Ehome vs Aster 选手采访
2021/03/11 DOTA
Python学习资料
2007/02/08 Python
python冒泡排序简单实现方法
2015/07/09 Python
用Python实现读写锁的示例代码
2018/11/05 Python
对python中 math模块下 atan 和 atan2的区别详解
2020/01/17 Python
Stubhub英国:购买体育、演唱会和剧院门票
2018/06/10 全球购物
Bose加拿大官方网站:美国知名音响品牌
2019/03/21 全球购物
你经历的项目中的SCM配置项主要有哪些?什么是配置项?
2013/11/04 面试题
英语翻译系毕业生求职信
2013/09/29 职场文书
超市5.1促销活动
2014/01/15 职场文书
旅游专业毕业生自荐书
2014/06/30 职场文书
科级干部群众路线教育实践活动个人对照检查材料
2014/09/19 职场文书