update: 数组的常见方法
This commit is contained in:
		
							parent
							
								
									db023d1dd3
								
							
						
					
					
						commit
						6cb4f316de
					
				@ -164,6 +164,23 @@ console.log(str6);
 | 
			
		||||
千古壹号[object Object]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## 字符串的不可变性
 | 
			
		||||
 | 
			
		||||
字符串里面的值不可被改变。虽然看上去可以改变内容,但其实是地址变了,内存中新开辟了一个内存空间。
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```js
 | 
			
		||||
var str = 'hello';
 | 
			
		||||
 | 
			
		||||
str = 'qianguyihao';
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
比如上面的代码,当重新给变量 str 赋值时,常量`hello`不会被修改,依然保存在内存中;str 会改为指向`qianguyihao`。
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## 模板字面量(模板字符串)
 | 
			
		||||
 | 
			
		||||
ES6中引入了**模板字面量**,让我们省去了字符串拼接的烦恼。
 | 
			
		||||
 | 
			
		||||
@ -407,6 +407,8 @@ console.log(Date.now()); // 打印结果举例:1589448165370
 | 
			
		||||
 | 
			
		||||
Moment.js 是一个轻量级的JavaScript时间库,我们可以利用它很方便地进行时间操作,提升开发效率。
 | 
			
		||||
 | 
			
		||||
- 中文官网:<http://momentjs.cn/>
 | 
			
		||||
 | 
			
		||||
使用举例:
 | 
			
		||||
 | 
			
		||||
```html
 | 
			
		||||
@ -438,7 +440,7 @@ Moment.js是一个轻量级的JavaScript时间库,我们可以利用它很方
 | 
			
		||||
 | 
			
		||||
## 我的公众号
 | 
			
		||||
 | 
			
		||||
想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**(id:`qianguyihao`)。
 | 
			
		||||
想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**。
 | 
			
		||||
 | 
			
		||||
扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外:
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -1,16 +0,0 @@
 | 
			
		||||
 | 
			
		||||
## 字符串的不可变性
 | 
			
		||||
 | 
			
		||||
字符串里面的值不可被改变。虽然看上去可以改变内容,但其实是地址变了,内存中新开辟了一个内存空间。
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```js
 | 
			
		||||
var str = 'hello';
 | 
			
		||||
 | 
			
		||||
str = 'qianguyihao';
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
比如上面的代码,当重新给变量 str 赋值时,常量`hello`不会被修改,依然保存在内存中;str 会改为指向`qianguyihao`。
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										274
									
								
								04-JavaScript基础/16-数组简介.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										274
									
								
								04-JavaScript基础/16-数组简介.md
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,274 @@
 | 
			
		||||
> 之前学习的数据类型,只能存储一个值(字符串也为一个值)。如果我们想存储多个值,就可以使用数组。
 | 
			
		||||
 | 
			
		||||
## 数组简介
 | 
			
		||||
 | 
			
		||||
数组(Array)是属于**内置对象**,我们可以在[MDN](https://developer.mozilla.org/zh-CN/)网站上查询各种方法。
 | 
			
		||||
 | 
			
		||||
数组和普通对象的功能类似,也是用来存储一些值的。不同的是:
 | 
			
		||||
 | 
			
		||||
-   普通对象是使用字符串作为属性名的,而数组是使用数字作为**索引**来操作元素。索引:从 0 开始的整数就是索引。
 | 
			
		||||
 | 
			
		||||
数组的存储性能比普通对象要好。在实际开发中我们经常使用数组来存储一些数据(尤其是**列表数据**),使用频率非常高。
 | 
			
		||||
 | 
			
		||||

 | 
			
		||||
 | 
			
		||||
比如说,上面这个页面的列表数据,它的结构就是一个大数组。
 | 
			
		||||
 | 
			
		||||
数组中的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。数组的元素中,如果存放的是数组,我们就称这种数组为二维数组。
 | 
			
		||||
 | 
			
		||||
接下来,我们讲一讲数组的基本操作。
 | 
			
		||||
 | 
			
		||||
## 创建数组对象
 | 
			
		||||
 | 
			
		||||
### 方式一:使用字面量创建数组
 | 
			
		||||
 | 
			
		||||
举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr1 = []; // 创建一个空的数组
 | 
			
		||||
 | 
			
		||||
var arr2 = [1, 2, 3]; // 创建带初始值的数组
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
方式一最简单,也用得最多。
 | 
			
		||||
 | 
			
		||||
### 方式二:使用构造函数创建数组
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
let arr = new Array(参数);
 | 
			
		||||
 | 
			
		||||
let arr = Array(参数);
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
如果**参数为空**,则表示创建一个空数组;如果参数是**一个数值**时,表示数组的长度;如果有多个参数时,表示数组中的元素。
 | 
			
		||||
 | 
			
		||||
来举个例子:
 | 
			
		||||
 | 
			
		||||
```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
 | 
			
		||||
object;
 | 
			
		||||
 | 
			
		||||
arr1 = [11, 12, 13];
 | 
			
		||||
arr2 = [];
 | 
			
		||||
arr3 = [null, null, null, null];
 | 
			
		||||
arr4 = [15, 16, 17];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
从上方打印结果的第一行里,可以看出,数组的类型其实也是属于**对象**。
 | 
			
		||||
 | 
			
		||||
### 数组中的元素的类型
 | 
			
		||||
 | 
			
		||||
数组中可以存放**任意类型**的数据,例如字符串、数字、布尔值、对象等。
 | 
			
		||||
 | 
			
		||||
比如:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
const arr = ['qianguyihao', 28, true, { name: 'qianguyihao' }];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
我们甚至还可以存放**多维数组**(数组里面放数组)。比如:
 | 
			
		||||
 | 
			
		||||
```js
 | 
			
		||||
const arr2 = [
 | 
			
		||||
    [11, 12, 13],
 | 
			
		||||
    [21, 22, 23],
 | 
			
		||||
];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## 数组的基本操作
 | 
			
		||||
 | 
			
		||||
### 数组的索引
 | 
			
		||||
 | 
			
		||||
**索引** (下标) :用来访问数组元素的序号,代表的是数组中的元素在数组中的位置(下标从 0 开始算起)。
 | 
			
		||||
 | 
			
		||||
数组可以通过索引来访问、设置、修改对应的数组元素。我们继续看看。
 | 
			
		||||
 | 
			
		||||
### 向数组中添加元素
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
数组[索引] = 值;
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr = [];
 | 
			
		||||
 | 
			
		||||
// 向数组中添加元素
 | 
			
		||||
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]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 获取数组中的元素
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
数组[索引];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
如果读取不存在的索引(比如元素没那么多),系统不会报错,而是返回 undefined。
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr = [21, 22, 23];
 | 
			
		||||
 | 
			
		||||
console.log(arr[0]); // 打印结果:21
 | 
			
		||||
console.log(arr[5]); // 打印结果:undefined
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 获取数组的长度
 | 
			
		||||
 | 
			
		||||
可以使用`length`属性来获取数组的长度(即“元素的个数”)。
 | 
			
		||||
 | 
			
		||||
数组的长度是元素个数,不要跟索引号混淆。
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```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
 | 
			
		||||
[11][(21, 22, 23, null, null)];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 遍历数组
 | 
			
		||||
 | 
			
		||||
**遍历**: 就是把数组中的每个元素从头到尾都访问一次。
 | 
			
		||||
 | 
			
		||||
最简单的做法是通过 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:冒泡排序
 | 
			
		||||
 | 
			
		||||
代码实现:
 | 
			
		||||
 | 
			
		||||
```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]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## 我的公众号
 | 
			
		||||
 | 
			
		||||
想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**(id:`qianguyihao`)。
 | 
			
		||||
 | 
			
		||||
扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外:
 | 
			
		||||
 | 
			
		||||

 | 
			
		||||
@ -1,264 +0,0 @@
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
> 之前学习的数据类型,只能存储一个值(字符串为一个值)。如果我们想存储多个值,就可以使用数组。
 | 
			
		||||
 | 
			
		||||
## 数组简介
 | 
			
		||||
 | 
			
		||||
数组(Array)是属于**内置对象**,我们可以在[MDN](https://developer.mozilla.org/zh-CN/)网站上查询各种方法。
 | 
			
		||||
 | 
			
		||||
数组和普通对象的功能类似,也是用来存储一些值的。不同的是:
 | 
			
		||||
 | 
			
		||||
- 普通对象是使用字符串作为属性名的,而数组是使用数字来作为**索引**来操作元素。索引:从0开始的整数就是索引。
 | 
			
		||||
 | 
			
		||||
数组的存储性能比普通对象要好。在实际开发中我们经常使用数组来存储一些数据,使用频率非常高。
 | 
			
		||||
 | 
			
		||||
数组中的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。数组的元素中,如果存放的是数组,我们就称这种数组为二维数组。
 | 
			
		||||
 | 
			
		||||
接下来,我们讲一讲数组的基本操作。
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## 创建数组对象
 | 
			
		||||
 | 
			
		||||
### 方式一:使用数组字面量创建数组
 | 
			
		||||
 | 
			
		||||
举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr1 = []; // 创建一个空的数组
 | 
			
		||||
 | 
			
		||||
var arr2 = [1,2,3]; // 创建带初始值的数组
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
方式一最简单,也用得最多。
 | 
			
		||||
 | 
			
		||||
### 方式二:使用构造函数创建数组
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
var arr = new Array(参数);
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
如果**参数为空**,则表示创建一个空数组;如果参数是**一个数值**时,表示数组的长度;参数位置是**多个数值**时,表示数组中的元素。
 | 
			
		||||
 | 
			
		||||
来举个例子:
 | 
			
		||||
 | 
			
		||||
```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
 | 
			
		||||
    object
 | 
			
		||||
 | 
			
		||||
    arr1 = [11,12,13]
 | 
			
		||||
    arr2 = []
 | 
			
		||||
    arr3 = [null,null,null,null]
 | 
			
		||||
    arr4 = [15,16,17]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
从上方打印结果的第一行里,可以看出,数组的类型其实也是属于**对象**。
 | 
			
		||||
 | 
			
		||||
### 数组中的元素的类型
 | 
			
		||||
 | 
			
		||||
数组中可以存放**任意类型**的数据,例如字符串、数字、布尔值、对象等。
 | 
			
		||||
 | 
			
		||||
比如:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr = ['qianguyihao', 28, true, {name: 'qianguyihao'}];
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## 数组的基本操作
 | 
			
		||||
 | 
			
		||||
### 数组的索引
 | 
			
		||||
 | 
			
		||||
**索引** (下标) :用来访问数组元素的序号,代表的是数组中的元素在数组中的位置(下标从 0 开始算起)。
 | 
			
		||||
 | 
			
		||||
数组可以通过索引来访问、设置、修改对应的数组元素。我们继续看看。
 | 
			
		||||
 | 
			
		||||
### 向数组中添加元素
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
数组[索引] = 值
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
var arr = [];
 | 
			
		||||
 | 
			
		||||
// 向数组中添加元素
 | 
			
		||||
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]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 获取数组中的元素
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
    数组[索引]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
如果读取不存在的索引(比如元素没那么多),系统不会报错,而是返回undefined。
 | 
			
		||||
 | 
			
		||||
代码举例:
 | 
			
		||||
 | 
			
		||||
```javascript
 | 
			
		||||
    var arr = [21, 22, 23];
 | 
			
		||||
 | 
			
		||||
    console.log(arr[0]); // 打印结果:21
 | 
			
		||||
    console.log(arr[5]); // 打印结果:undefined
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 获取数组的长度
 | 
			
		||||
 | 
			
		||||
可以使用`length`属性来获取数组的长度(即“元素的个数”)。
 | 
			
		||||
 | 
			
		||||
数组的长度是元素个数,不要跟索引号混淆。
 | 
			
		||||
 | 
			
		||||
语法:
 | 
			
		||||
 | 
			
		||||
```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
 | 
			
		||||
    [11]
 | 
			
		||||
 | 
			
		||||
    [21,22,23,null,null]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
### 遍历数组
 | 
			
		||||
 | 
			
		||||
**遍历**: 就是把数组中的每个元素从头到尾都访问一次。
 | 
			
		||||
 | 
			
		||||
最简单的做法是通过 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:冒泡排序
 | 
			
		||||
 | 
			
		||||
代码实现:
 | 
			
		||||
 | 
			
		||||
```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]
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## 我的公众号
 | 
			
		||||
 | 
			
		||||
想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**(id:`qianguyihao`)。
 | 
			
		||||
 | 
			
		||||
扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外:
 | 
			
		||||
 | 
			
		||||

 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user