Webcourse/04-JavaScript基础/15-数组简介.md

265 lines
6.1 KiB
JavaScript
Raw Normal View History

2019-02-03 13:15:48 +08:00
> 之前学习的数据类型只能存储一个值字符串为一个值如果我们想存储多个值就可以使用数组
## 数组简介
数组Array是属于**内置对象**我们可以在[MDN](https://developer.mozilla.org/zh-CN/)网站上查询各种方法。
数组和普通对象的功能类似也是用来存储一些值的不同的是
- 普通对象是使用字符串作为属性名的而数组是使用数字来作为**索引**来操作元素索引从0开始的整数就是索引
数组的存储性能比普通对象要好在实际开发中我们经常使用数组来存储一些数据使用频率非常高
2019-12-26 17:52:03 +08:00
数组中的元素可以是任意的数据类型也可以是对象也可以是函数也可以是数组数组的元素中如果存放的是数组我们就称这种数组为二维数组
2019-02-03 13:15:48 +08:00
2019-12-26 17:52:03 +08:00
接下来我们讲一讲数组的基本操作
2019-02-03 13:15:48 +08:00
2019-12-13 16:01:36 +08:00
## 创建数组对象
### 方式一使用数组字面量创建数组
2019-02-03 13:15:48 +08:00
2019-12-13 16:01:36 +08:00
举例
2019-02-03 13:15:48 +08:00
```javascript
2019-12-13 16:01:36 +08:00
var arr1 = []; // 创建一个空的数组
var arr2 = [1,2,3]; // 创建带初始值的数组
2019-02-03 13:15:48 +08:00
```
2019-12-13 16:01:36 +08:00
方式一最简单也用得最多
### 方式二使用构造函数创建数组
2019-02-03 13:15:48 +08:00
语法
```
var arr = new Array(参数);
```
2019-12-13 16:01:36 +08:00
如果**参数为空**则表示创建一个空数组如果参数是**一个数值**表示数组的长度参数位置是**多个数值**表示数组中的元素
2019-02-03 13:15:48 +08:00
2019-12-13 16:01:36 +08:00
来举个例子
2019-02-03 13:15:48 +08:00
```javascript
// 方式一
var arr1 = [11, 12, 13];
// 方式二
var arr2 = new Array(); // 参数为空
var arr3 = new Array(4); // 参数为一个数值
var arr4 = new Array(15, 16, 17); // 参数为多个数值
console.log(typeof arr1); // 打印结果object
console.log("arr1 = " + JSON.stringify(arr1));
console.log("arr2 = " + JSON.stringify(arr2));
console.log("arr3 = " + JSON.stringify(arr3));
console.log("arr4 = " + JSON.stringify(arr4));
```
打印结果
```javascript
2019-12-26 17:52:03 +08:00
object
2019-02-03 13:15:48 +08:00
2019-12-26 17:52:03 +08:00
arr1 = [11,12,13]
arr2 = []
arr3 = [null,null,null,null]
arr4 = [15,16,17]
2019-02-03 13:15:48 +08:00
```
从上方打印结果的第一行里可以看出数组的类型其实也是属于**对象**
2019-12-13 16:01:36 +08:00
### 数组中的元素的类型
数组中可以存放**任意类型**的数据例如字符串数字布尔值对象等
比如
```javascript
var arr = ['qianguyihao', 28, true, {name: 'qianguyihao'}];
```
## 数组的基本操作
### 数组的索引
**索引** (下标) 用来访问数组元素的序号代表的是数组中的元素在数组中的位置下标从 0 开始算起
数组可以通过索引来访问设置修改对应的数组元素我们继续看看
2019-02-03 13:15:48 +08:00
### 向数组中添加元素
语法
```javascript
2019-12-26 17:52:03 +08:00
数组[索引] =
2019-02-03 13:15:48 +08:00
```
代码举例
```javascript
2019-12-13 16:01:36 +08:00
var arr = [];
2019-02-03 13:15:48 +08:00
2019-12-13 16:01:36 +08:00
// 向数组中添加元素
arr[0] = 10;
arr[1] = 20;
arr[2] = 30;
arr[3] = 40;
arr[5] = 50;
console.log(JSON.stringify(arr));
```
打印结果
```
[10,20,30,40,null,50]
2019-02-03 13:15:48 +08:00
```
### 获取数组中的元素
语法
```javascript
数组[索引]
```
如果读取不存在的索引比如元素没那么多系统不会报错而是返回undefined
代码举例
```javascript
var arr = [21, 22, 23];
console.log(arr[0]); // 打印结果21
console.log(arr[5]); // 打印结果undefined
```
### 获取数组的长度
2019-12-13 16:01:36 +08:00
可以使用`length`属性来获取数组的长度(元素的个数)
2019-02-03 13:15:48 +08:00
2020-02-06 18:01:18 +08:00
数组的长度是元素个数不要跟索引号混淆
2019-02-03 13:15:48 +08:00
语法
```javascript
数组的长度 = 数组名.length
```
代码举例
```javascript
var arr = [21, 22, 23];
console.log(arr.length); // 打印结果3
```
补充
对于连续的数组使用length可以获取到数组的长度元素的个数对于非连续的数组使用length会获取到数组的最大的索引+1因此尽量不要创建非连续的数组
### 修改数组的长度修改length
- 如果修改的length大于原长度则多出部分会空出来置为 null
- 如果修改的length小于原长度则多出的元素会被删除数组将从后面删除元素
- 特例伪数组arguments的长度可以修改但是不能修改里面的元素后面单独讲
代码举例
```javascript
var arr1 = [11, 12, 13];
var arr2 = [21, 22, 23];
// 修改数组 arr1 的 length
arr1.length = 1;
console.log(JSON.stringify(arr1));
// 修改数组 arr2 的 length
arr2.length = 5;
console.log(JSON.stringify(arr2));
```
打印结果
```javascript
2019-12-26 17:52:03 +08:00
[11]
2019-02-03 13:15:48 +08:00
2019-12-26 17:52:03 +08:00
[21,22,23,null,null]
2019-02-03 13:15:48 +08:00
```
2019-12-13 16:01:36 +08:00
### 遍历数组
**遍历**: 就是把数组中的每个元素从头到尾都访问一次
最简单的做法是通过 for 循环遍历数组中的每一项举例
```javascript
var arr = [10, 20, 30, 40, 50];
for (var i = 0; i < arr.length; i++) {
console.log(arr[i]); // 打印出数组中的每一项
}
```
下一篇文章会学习数组的各种方法到时候会有更多的做法去遍历数组
## 案例
### 例1翻转数组
代码实现
```javascript
var arr = [10, 20, 30, 40, 50]; // 原始数组
var newArr = []; // 翻转后的数组
for (var i = 0; i < arr.length; i++) {
newArr[i] = arr[arr.length - i - 1];
}
console.log(JSON.stringify(newArr));
```
打印结果
```
[50,40,30,20,10]
```
### 例2冒泡排序
2019-02-03 13:15:48 +08:00
2019-12-13 16:01:36 +08:00
代码实现
```javascript
var arr = [20, 10, 50, 30, 40];
for (var i = 0; i < arr.length - 1; i++) {
for (var j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
var temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
console.log(JSON.stringify(arr));
```
打印结果
```
[10,20,30,40,50]
```
2019-02-03 13:15:48 +08:00
## 我的公众号
2019-12-13 16:01:36 +08:00
想学习**代码之外的技能**不妨关注我的微信公众号**千古壹号**id`qianguyihao`
2019-02-03 13:15:48 +08:00
扫一扫你将发现另一个全新的世界而这将是一场美丽的意外
2019-12-13 16:01:36 +08:00
![](http://img.smyhvae.com/20200101.png)