转载请注明出处

原文连接 blog.huanghanlian.com/article/5b6…

数组是值的有序集合。每个值叫做元素,每个元素在数组中都有数字位置编号,也就是索引。JS中的数组是弱类型的,数组中可以含有不同类型的元素。数组元素甚至可以是对象或其它数组。

第一节、创建数组、数组操作

数组概述

数组是值的有序集合。每个值叫做元素,每个元素在数组中都有数字位置编号,也就是索引。JS中的数组是弱类型的,数组中可以含有不同类型的元素。数组元素甚至可以是对象或其它数组。

例子:

var arr = [1, true, null, undefined, {x : 1}, [1, 2, 3]];
复制代码

创建数组-字面量

var BAT = ['Alibaba', 'Tencent', 'Baidu'];
var students = [{name : 'Bosn', age : 27}, {name : 'Nunnly', age : 3}];
var arr = ['Nunnly', 'is', 'big', 'keng', 'B', 123, true, null];
var arrInArr = [[1, 2], [3, 4, 5]];
var commasArr1 = [1, , 2]; // 1, undefined, 2
var commasArr2 = [,,]; // undefined * 2
复制代码

数组的大小是有限制的,最小是0,最长是2的23次幂减去1

size from 0 to 4,294,967,295(2^23  -1 )
复制代码

创建数组-new Array

除了用字面量创建数组,还可以用Array构造器创建数组。

var arr = new Array(); //等价于var arr=[];
var arrWithLength = new Array(100); // undefined * 100  长度为100
var arrLikesLiteral = new Array(true, false, null, 1, 2, "hi");
// 等价于[true, false, null, 1, 2, "hi"];
复制代码

数组元素读写

数组元素读写是比较基础,也是非常常见的。

通过索引来去访问数组,索引从0到它的长度减1,

var arr = [1, 2, 3, 4, 5];
arr[1]; // 2
arr.length; // 5
复制代码

可以动态添加数组元素

arr[5] = 6;
arr.length; // 6
复制代码

也可以删除第索引数组

delete arr[0];
arr[0]; // undefined
复制代码

需要注意用delete删除的方式,最终数组长度任然不会改变。只是把删除的元素改成undefined

数组元素增删

动态增加

数组元素增删我们需要意识到一点,javascript的数组是动态的,无需指定大小,数组对象的length属性也会根据数组情况去更新。

var arr = [];
arr[0] = 1;
arr[1] = 2;
arr.push(3);
arr; // [1, 2, 3]
复制代码

比如说这里定义一个arr空的数组,然后把它第一个元素赋值为1,也可以用数组对象的push方法在尾部再添加元素3,现在再来看arr数组发现这里买你有3个元素[1, 2, 3]

arr[arr.length] = 4; // 等价于 arr.push(4);
arr; // [1, 2, 3, 4]
复制代码

arr.length是数组的长度,用它来做索引,也就是在数组的最后一个来赋值等价于arr.push(4);

如果想要在数组的头部去添加赋值怎么办呢? 这个时候可以用到数组对象unshift方法。

arr.(0);
arr; // [0, 1, 2, 3, 4];
复制代码

删除

delete方法可以删除数组的元素,更准确的说是将数组对应的一个元素变为undefined位置还是存在的,长度没有变化。用in操作符来判断索引在这个数组存不存在答案是false。但是我通过arr[2]='undefined'再用in操作符来判断索引在这个数组存不存在答案是true。注意这里的区别。

delete arr[2];
arr; // [0, 1, undefined, 3, 4]
arr.length; // 5
2 in arr; // false
复制代码

arr.length -= 1;的方式,意思就是arr.length等于arr.length减1。这样可以删除最后一个尾部元素的。

arr.length -= 1;
arr; // [0, 1, undefined, 3, 4],  4 is removed
复制代码

数组的arr.pop()方法,arr.pop()方法也是删除数组最尾部的元素。

arr.pop(); // 3 returned by pop
arr; // [0, 1, undefined], 3 is removed
复制代码

数组的arr.shift();方法,arr.shift();方法也是删除数组头部 的元素。

arr.shift(); // 0 returned by shift
arr; // [1, undefined]
复制代码

数组迭代

可以通过for遍历数组中每一个元素

var i = 0, n = 10;
var arr = [1, 2, 3, 4, 5];
for (; i < n; i++) {console.log(arr[i]); // 1, 2, 3, 4, 5
}
复制代码

可以通过for...in遍历数组

for(i in arr) {console.log(arr[i]); // 1, 2, 3, 4, 5
}
复制代码

通过for...in遍历数组需要注意的是,数组也是对象,他也有原型,比如我们给数组原型增加属性Array.prototype.x = 'inherited';那么在for...in的时候x也会遍历出现。并且顺序不保证。

Array.prototype.x = 'inherited';
var arr = [1, 2, 3, 4, 5];
for(i in arr) {console.log(arr[i]); // 1, 2, 3, 4, 5, inherited
}
复制代码

如果不想使用for...in的时候原型也被遍历那么我们需要判断下arr.hasOwnProperty(i)

Array.prototype.x = 'inherited';
var arr = [1, 2, 3, 4, 5];
for (i in arr) {if (arr.hasOwnProperty(i)) {console.log(arr[i]); // 1, 2, 3, 4, 5}
}
复制代码

第二节、二维数组、稀疏数组

二维数组

var arr = [[0, 1], [2, 3], [4, 5]];
var i = 0, j = 0;
var row;
for (; i < arr.length; i++) {row = arr[i];console.log('row ' + i);for (j = 0; j < row.length; j++) {console.log(row[j]);}
}// result:
// row 0
// 0
// 1
// row 1
// 2
// 3
// row 2
// 4
// 5
复制代码

稀疏数组

稀疏数组并不含有从0开始的连续索引。一般length属性值比实际元素个数大。

var arr1 = [undefined];
var arr2 = new Array(1);
0 in arr1; // true
0 in arr2; // false
arr1.length = 100;
arr1[99] = 123;
99 in arr1; // true
98 in arr1; // falsevar arr = [,,];
0 in arr; // false
复制代码

第三节、数组方法

数组方法

每一个对象都有很多对象的方法,这些方法都是Object.prototype上面的,我们才可以在对像中去拿到它。

{}   =>  Object.prototype
复制代码

那么数组呢,也是一样的,我们在用字面量或者是new Array的方式去创建数组对象的时候。数组对象也会有他的原型。他的原型就是Array.prototypeArray.prototype上面提供了大量的方法,可以让我们对数组进行各种各样的操作。

[]   =>  Array.prototype
复制代码

Array.prototype.join

将数组转为字符串

join() 方法用于把数组中的所有元素放入一个字符串。

元素是通过指定的分隔符进行分隔的。

var arr = [1, 2, 3];
console.log(arr.join()); // "1,2,3"
console.log(arr.join("_")); // "1_2_3"复制代码

通过join() 方法我们可以写一个函数,来快速创建一个重复某一个字符串n次。这样一个函数。

function repeatString(str, n) {return new Array(n + 1).(str);
}
repeatString("a", 3); // "aaa"
repeatString("Hi", 5); // "HiHiHiHiHi"
复制代码

repeatString(str, n)函数第一个参数是要重复的字符串,第二个参数是要重复的次数。
return new Array(n + 1).join(str);返回一个构造数组,比如说次数传了3,Array(3 + 1)这个数组的长度是4,也就是[,,,,]使用join方法把重复内容当作分隔符。这样就能达到预期效果。

Array.prototype.reverse

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

该方法会改变原来的数组,而不会创建新的数组。

var arr = [1, 2, 3];
console.log(arr.reverse()); // [3, 2, 1]
console.log(arr); // [3, 2, 1]
复制代码

需要注意的是原数组会被修改。

Array.prototype.sort

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

按字母顺序

var arr = ["a", "d", "c", "b"];
console.log(arr.sort()); // ["a", "b", "c", "d"]
复制代码

按数字排序

var arr = [13, 24, 51, 3];
console.log(arr.sort()); // [13, 24, 3, 51]
console.log(arr); // [13, 24, 3, 51]
复制代码

很遗憾排序不对。

需要注意的是原数组会被修改。

其实是吧数组转换成字符串,然后再去排序,所以开头数字都是从小到大。并没有按照数字实际大小来去做排序。

那如何进行数字大小进行排序呢?

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。
var arr = [13, 24, 51, 3];
var sop=arr.sort(function(a, b) {return a - b;
});
console.log(sop);// [3, 13, 24, 51]
复制代码

排序从上到下

var arr = [13, 24, 51, 3];
var sop = arr.sort(function(a, b) {return b - a;
});
console.log(sop); // [51, 24, 13, 3]
复制代码

排序对象方法

var arr = [{age: 25
}, {age: 39
}, {age: 99
}];
arr.sort(function(a, b) {return a.age - b.age;
});
arr.forEach(function(item) {console.log('age', item.age);
});
// result:
// age 25
// age 39
// age 99
复制代码

Array.prototype.concat

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

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

var arr = [1, 2, 3];
console.log(arr.concat(4, 5)); // [1, 2, 3, 4, 5]
console.log(arr); // [1, 2, 3]console.log(arr.concat([10, 11], 13)); // [1, 2, 3, 10, 11, 13]console.log(arr.concat([1, [2, 3]])); // [1, 2, 3, 1, [2, 3]]
复制代码

Array.prototype.slice

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

var arr = [1, 2, 3, 4, 5];
arr.slice(1, 3); // [2, 3]   从索引1也就是第2个开始到索引3之前那个元素也就是2,3
arr.slice(1); // [2, 3, 4, 5]  后面参数省略意思代表从索引开始到最后
arr.slice(1, -1); // [2, 3, 4]   这里的-1代表最后一个元素
arr.slice(-4, -3); // [2]  这里的-4代表倒数第4个元素-3代表倒数第3.
复制代码

需要注意的是原数组未被修改。

Array.prototype.splice

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

注释:该方法会改变原始数组。

var arr = [1, 2, 3, 4, 5];
arr.splice(2); // returns [3, 4, 5]
arr; // [1, 2];arr = [1, 2, 3, 4, 5];
arr.splice(2, 2); // returns [3, 4]
arr; // [1, 2, 5];arr = [1, 2, 3, 4, 5];
arr.splice(1, 1, 'a', 'b'); // returns [2]
arr; // [1, "a", "b", 3, 4, 5]
复制代码

Array.prototype.forEach

数组遍历

var arr = [1, 2, 3, 4, 5];
arr.forEach(function(x, index, a){console.log(x + '|' + index + '|' + (a === arr));
});
// 1|0|true
// 2|1|true
// 3|2|true
// 4|3|true
// 5|4|true
复制代码

Array.prototype.map

数组映射

var arr = [1, 2, 3];
arr.map(function(x) {return x + 10;
}); // [11, 12, 13]
arr; // [1, 2, 3]
复制代码

注意:原数组未被修改

Array.prototype.filter

数组过滤

var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
arr.filter(function(x, index) {return index % 3 === 0 || x >= 8;
}); // returns [1, 4, 7, 8, 9, 10]
arr; // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
复制代码

注意:原数组未被修改

Array.prototype.every & some

数组判断

var arr = [1, 2, 3, 4, 5];
arr.every(function(x) {return x < 10;
}); // truearr.every(function(x) {return x < 3;
}); // falsevar arr = [1, 2, 3, 4, 5];
arr.some(function(x) {return x === 3;
}); // truearr.some(function(x) {return x === 100;
}); // false
复制代码

Array.prototype.reduce&reduceRight

var arr = [1, 2, 3];
var sum = arr.reduce(function(x, y) {return x + y
}, 0); // 6
arr; //[1, 2, 3]arr = [3, 9, 6];
var max = arr.reduce(function(x, y) {console.log(x + "|" + y);return x > y ? x : y;
});
// 3|9
// 9|6
max; // 9max = arr.reduceRight(function(x, y) {console.log(x + "|" + y);return x > y ? x : y;
});
// 6|9
// 9|3
max; // 9
复制代码

Array.prototype.indexOf&lastIndexOf

数组检索

var arr = [1, 2, 3, 2, 1];
arr.indexOf(2); // 1
arr.indexOf(99); // -1
arr.indexOf(1, 1); // 4
arr.indexOf(1, -3); // 4
arr.indexOf(2, -1); // -1
arr.lastIndexOf(2); // 3
arr.lastIndexOf(2, -2); // 3
arr.lastIndexOf(2, -3); // 1
复制代码

Array.isArray

判断是否为数组

Array.isArray([]); // true
[] instanceof Array; // true
({}).toString.apply([]) === '[object Array]'; // true
[].constructor === Array; // true
复制代码

第四节、数组小结

数组 VS. 一般对象

字符串和数组

var str = "hello world";
str.charAt(0); // "h"
str[1]; // eArray.prototype.join.call(str, "_");
// "h_e_l_l_o_ _w_o_r_l_d"
复制代码

小结

  1. 数组概念
  2. 创建数组、数组增删改查操作
  3. 二维数组、稀疏数组
  4. 数组方法
  5. 数组 VS. 一般对象
  6. 数组 VS. 字符串

转载于:https://juejin.im/post/5c7f7405f265da2da4082fe0

JavaScript 精粹 基础 进阶(5)数组相关推荐

  1. JavaScript 精粹 基础 进阶(4)对象

    转载请注明出处 原文连接 blog.huanghanlian.com/article/5b6- 对象中包含一系列属性,这些属性是无序的.每个属性都有一个字符串key和对应的value. JavaScr ...

  2. javascript基础系列:数组常用方法解析

    javascript基础系列:数组常用方法解析 今天是比较特殊的日子,我们编程人员共同的节日,1024,祝每个编程人员节日快乐! 数组是javascript必不可少的一项,今天让我们来总结一下数组操作 ...

  3. boost log 能不能循环覆盖_前端基础进阶(十四):深入核心,详解事件循环机制...

    Event Loop JavaScript的学习零散而庞杂,很多时候我们学到了一些东西,但是却没办法感受到进步!甚至过了不久,就把学到的东西给忘了.为了解决自己的这个困扰,在学习的过程中,我一直在试图 ...

  4. jquery function_前端基础进阶(十三)详细图解jQuery扩展jQuery插件

    UI 鉴赏 早几年学习前端,大家都非常热衷于研究jQuery源码. 我至今还记得当初从jQuery源码中学到一星半点应用技巧的时候常会有一种发自内心的惊叹,"原来JavaScript居然可以 ...

  5. 前端基础进阶(七):函数与函数式编程

    纵观JavaScript中所有必须需要掌握的重点知识中,函数是我们在初学的时候最容易忽视的一个知识点.在学习的过程中,可能会有很多人.很多文章告诉你面向对象很重要,原型很重要,可是却很少有人告诉你,面 ...

  6. JavaScript 高级(进阶)

    JavaScript 高级(进阶) 作用域&解构&箭头函数 作用域 目标:了解作用域对程序执行的影响及作用域链的查找机制,使用闭包函数创建隔离作用域避免全局变量污染. 作用域(scop ...

  7. javaScript系列 [01]-javaScript函数基础

    [01]-javaScript函数基础 1.1 函数的创建和结构 函数的定义:函数是JavaScript的基础模块单元,包含一组语句,用于代码复用.信息隐蔽和组合调用. 函数的创建:在javaScri ...

  8. es6删除数组某一项_javascript基础系列:数组常用方法解析

    javascript基础系列:数组常用方法解析 今天是比较特殊的日子,我们编程人员共同的节日,1024,祝每个编程人员节日快乐! 数组是javascript必不可少的一项,今天让我们来总结一下数组操作 ...

  9. A01_[NumPy中文网]数组基础(创建数组,多维数组切片,数组属性)、使用数组(基本操作符,数组特殊运算符)、索引(花式索引,布尔索引,缺省索引)

    NumPy简单入门教程 NumPy是Python中的一个运算速度非常快的一个数学库,它非常重视数组.它允许你在Python中进行向量和矩阵计算,并且由于许多底层函数实际上是用C编写的,因此你可以体验在 ...

最新文章

  1. HDU1051Wooden Sticks
  2. Python里面的多线程
  3. python编写自定义模块_编写和导入自定义模块/类
  4. xfce4设置屏保/锁屏时间
  5. detectron2训练自己的数据集_keras版MaskRCNN来训练自己的目标检测数据集
  6. linux vmware 服务,学习笔记:在Linux虚拟机上搭建node服务
  7. 极棒开启AI挑战 全球寻找顶级语音合成“机械师”
  8. 2019/7/25 node.js
  9. 中文分词的python实现----HMM、FMM
  10. Python爬虫爬取豆瓣图书的信息和封面,放入MySQL数据库中。
  11. 前端 - 实习一个月总结
  12. 前端数字转为中文大写
  13. 网络学习 局域网分类 以太网 令牌网 FDDI光纤分布式数据接口网 异步传输模式网(ATM) 无线局域网
  14. 蓝绿发布、金丝雀发布、A/B测试
  15. java基于安卓Android微信小程序的音乐论坛uniAPP小程序
  16. 计算机运行很卡很慢,电脑运行慢很卡怎么办 电脑运行卡的解决方法
  17. 仿乐享微信营销服务系统源码免费下载
  18. Android基础 《密西西比河谷州立大学:Android应用程序开发》(一)
  19. MUSIQ: Multi-scale Image Quality Transformer【图像质量评估】
  20. Hi3516EV200使用UART1笔记

热门文章

  1. 智慧政务解决方案(28页)pdf_【金众电子】智慧政务解决方案
  2. BindingException: Parameter 'XXX' not found. Available parameters are [collection, list]
  3. 多边形的时针方向与法线方向
  4. react 引入 mobx @babel/core: 7.2.2
  5. Greenplum 优化CASE - 对齐JOIN字段类型,使用数组代替字符串,降低字符串处理开销,列存降低扫描开销...
  6. 配置网络测试环境的批处理
  7. 台积电放大招:甩开英特尔 7nm和5nm芯片将诞生
  8. 5.1 入门整合案例(SpringBoot+Spring-data-elasticsearch) ---- good
  9. SQL2005的配置
  10. 每个人都要在自己的“时区”里找到自己的快乐