From f93fd2ee605221bf62171be6656266c6d89ba1f2 Mon Sep 17 00:00:00 2001 From: qianguyihao Date: Fri, 20 Sep 2019 20:19:36 +0800 Subject: [PATCH] =?UTF-8?q?add:=20map=E5=BA=94=E7=94=A8=E7=9A=84=E6=A1=88?= =?UTF-8?q?=E4=BE=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../15-数组的四个基本方法&数组的遍历.md | 810 +++++++++++++++++- ...8-内置对象:Date.md => 16-内置对象:Date.md} | 0 03-JavaScript基础/16-数组的常见方法.md | 417 --------- ...9-内置对象:Math.md => 17-内置对象:Math.md} | 0 03-JavaScript基础/17-数组的其他方法.md | 374 -------- .../{20-包装类.md => 18-包装类.md} | 0 ...置对象:String.md => 19-内置对象:String.md} | 0 .../{22-正则表达式.md => 20-正则表达式.md} | 0 .../{23-事件简介.md => 21-事件简介.md} | 0 ...M简介和DOM操作.md => 22-DOM简介和DOM操作.md} | 0 ...置行内样式.md => 23-通过style对象设置行内样式.md} | 0 10-ES6/02-ES5中的一些扩展.md | 2 +- 10-ES6/09-ES6:字符串、数组、对象的扩展.md | 2 +- 18-推荐链接/03-GitHub项目推荐.md | 4 + 14 files changed, 799 insertions(+), 810 deletions(-) rename 03-JavaScript基础/{18-内置对象:Date.md => 16-内置对象:Date.md} (100%) delete mode 100644 03-JavaScript基础/16-数组的常见方法.md rename 03-JavaScript基础/{19-内置对象:Math.md => 17-内置对象:Math.md} (100%) delete mode 100644 03-JavaScript基础/17-数组的其他方法.md rename 03-JavaScript基础/{20-包装类.md => 18-包装类.md} (100%) rename 03-JavaScript基础/{21-内置对象:String.md => 19-内置对象:String.md} (100%) rename 03-JavaScript基础/{22-正则表达式.md => 20-正则表达式.md} (100%) rename 03-JavaScript基础/{23-事件简介.md => 21-事件简介.md} (100%) rename 03-JavaScript基础/{24-DOM简介和DOM操作.md => 22-DOM简介和DOM操作.md} (100%) rename 03-JavaScript基础/{25-通过style对象设置行内样式.md => 23-通过style对象设置行内样式.md} (100%) diff --git a/03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md b/03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md index 6cbed70..23de224 100644 --- a/03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md +++ b/03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md @@ -2,7 +2,7 @@ ## 前言 -**数组的四个基本方法如下**: +**数组的四个基本方法如下**:(数组元素的添加和删除) | 方法 | 描述 | 备注 | |:-------------|:-------------|:-------------| @@ -11,6 +11,19 @@ | unshift() | 在数组**最前面**插入一个或多个元素,返回结果为**该数组新的长度**| 会改变原数组| | shift() | 删除数组中的**第一个**元素,返回结果为**被删除的元素**| 会改变原数组| + +**数组的常见方法如下**: + +| 方法 | 描述 | 备注 | +|:-------------|:-------------|:-------------| +| slice() | 从数组中**提取**指定的一个或多个元素,返回结果为**新的数组**| 不会改变原数组| +| splice() | 从数组中**删除**指定的一个或多个元素,返回结果为**新的数组**| 会改变原数组| +| concat() | 连接两个或多个数组,返回结果为**新的数组**| 不会改变原数组| +| join() | 将数组转换为字符串,返回结果为**转换后的字符串**| 不会改变原数组| +| reverse() | 反转数组,返回结果为**反转后的数组**| 会改变原数组| +| sort() | 对数组的元素,默认按照**Unicode编码**,从小到大进行排序| 会改变原数组| + + **遍历数组的方法如下**: | 方法 | 描述 | 备注 | @@ -18,10 +31,21 @@ | for循环 | 这个大家都懂| | | forEach()|和 for循环类似,但需要兼容IE8以上 |forEach() 没有返回值。也就是说,它的返回值是 undefined| | filter()| 返回结果是true的项,将组成新的数组。可以起到过滤的作用| 不会改变原数组| -| map()| 对原数组中的每一项进行加工 | | +| map()| 对原数组中的每一项进行加工,将组成新的数组 | 不会改变原数组 | | every()| 如果有一项返回false,则停止遍历 | 意思是,要求每一项都返回true,最终的结果才返回true | | some()| 只要有一项返回true,则停止遍历 | | +| reduce | | | +**数组的其他方法如下**: + +| 方法 | 描述 | 备注 | +|:-------------|:-------------|:-------------| +| indexOf(value) | 从前往后索引,获取 value 在数组中的第一个下标 | | +| lastIndexOf(value) | 从后往前索引,获取 value 在数组中的最后一个下标 | | +| find(function()) | 找出**第一个**满足「指定条件返回true」的元素。 | | +| findIndex(function()) | 找出**第一个**满足「指定条件返回true」的元素的index | | +| Array.from(arrayLike) | 将**伪数组**转化为**真数组**| | +| Array.of(value1, value2, value3) | 将**一系列值**转换成数组。| | ## 数组的四个基本方法(数组元素的添加和删除) @@ -119,6 +143,373 @@ ``` + + + + +## 数组的常见方法 + +### slice() + +`slice()`:从数组中提取指定的一个或者多个元素,返回结果为**新的数组**(不会改变原来的数组)。 + +备注:该方法不会改变原数组,而是将截取到的元素封装到一个新数组中返回。 + +**语法**: + +```javascript + 新数组 = 原数组.slice(开始位置的索引, 结束位置的索引); //注意:包含开始索引,不包含结束索引 +``` + +举例: + +```javascript + var arr = ["a", "b", "c", "d", "e", "f"]; + + var result1 = arr.slice(2); //从第二个值开始提取 + var result2 = arr.slice(-2); //提取最后两个元素 + var result3 = arr.slice(2, 4); //提取从第二个到第四个之间的值(不包括第四个值) + var result4 = arr.slice(4, 2); //空 + + console.log("arr:" + JSON.stringify(arr)); + console.log("result1:" + JSON.stringify(result1)); + console.log("result2:" + JSON.stringify(result2)); + console.log("result3:" + JSON.stringify(result3)); + console.log("result4:" + JSON.stringify(result4)); + +``` + +打印结果: + +```javascript + arr:["a","b","c","d","e","f"] + result1:["c","d","e","f"] + result2:["e","f"] + result3:["c","d"] + result4:[] +``` + + +**补充**: + +很多前端开发人员会用 slice()将伪数组,转化为真数组。写法如下: + +```javascript +array = Array.prototye.slice.call(arrayLike) +或者 +array = [].slice.call(arrayLike) +``` + + +ES6 看不下去这种蹩脚的转化方法,于是出了一个新的 API:(专门用来将伪数组转化成真数组) + +```javascript +array = Array.from(arrayLike) +``` + + +### splice() + +`splice()`:从数组中**删除**指定的一个或多个元素,返回结果为**新的数组**(会改变原来的数组,会将指定元素从原数组中删除)。 + +语法: + +```javascript + 新数组 = 原数组.splice(起始索引index, 需要删除的个数, 第三个参数, 第四个参数...); +``` + +上方语法中,第三个及之后的参数,表示:向原数组中添加新的元素,这些元素将会自动插入到开始位置索引的前面。 + +举例1: + +```javascript + var arr1 = ["a", "b", "c", "d", "e", "f"]; + var result1 = arr1.splice(1); //从第index为1的位置开始,删除元素 + + console.log("arr1:" + JSON.stringify(arr1)); + console.log("result1:" + JSON.stringify(result1)); + + console.log("-----------------------"); + + var arr2 = ["a", "b", "c", "d", "e", "f"]; + var result2 = arr2.splice(-2); //从第一个位置开始,删除元素 + + console.log("arr2:" + JSON.stringify(arr2)); + console.log("result2:" + JSON.stringify(result2)); + + console.log("-----------------------"); + + var arr3 = ["a", "b", "c", "d", "e", "f"]; + var result3 = arr3.splice(1, 3); //从第index为1的位置开始删除元素,一共删除三个元素 + + console.log("arr3:" + JSON.stringify(arr3)); + console.log("result3:" + JSON.stringify(result3)); + + console.log("-----------------------"); +``` + +打印结果: + +```javascript +arr1:["a"] +result1:["b","c","d","e","f"] +----------------------- + +arr2:["a","b","c","d"] +result2:["e","f"] +----------------------- + +arr3:["a","e","f"] +result3:["b","c","d"] +----------------------- +``` + +举例2:(我们来看看**第三个参数**的用法) + +```javascript +var arr4 = ["a", "b", "c", "d", "e", "f"]; + +//从第index为1的位置开始删除元素,一共删除三个元素。并且在 index=1 的前面追加两个元素 +var result4 = arr4.splice(1, 3, "千古壹号", "vae"); + +console.log("arr4:" + JSON.stringify(arr4)); +console.log("result4:" + JSON.stringify(result4)); +``` + +打印结果: + +```javascript +arr4:["a","千古壹号","vae","e","f"] +result4:["b","c","d"] +``` + +### concat() + +`concat()`:连接两个或多个数组,返回结果为**新的数组**。(不会改变原数组) + +语法: + +```javascript + 新数组 = 数组1.concat(数组2, 数组3 ...); + +``` + +举例: + +```javascript + var arr1 = [1, 2, 3]; + var arr2 = ["a", "b", "c"]; + var arr3 = ["千古壹号", "vae"]; + + var result1 = arr1.concat(arr2); + + var result2 = arr2.concat(arr1, arr3); + + console.log("arr1 =" + JSON.stringify(arr1)); + console.log("arr2 =" + JSON.stringify(arr2)); + console.log("arr3 =" + JSON.stringify(arr3)); + + console.log("result1 =" + JSON.stringify(result1)); + console.log("result2 =" + JSON.stringify(result2)); +``` + +打印结果: + +```javascript +arr1 =[1,2,3] +arr2 =["a","b","c"] +arr3 =["千古壹号","vae"] + +result1 =[1,2,3,"a","b","c"] +result2 =["a","b","c",1,2,3,"千古壹号","vae"] +``` + +从打印结果中可以看到,原数组并没有被修改。 + +### join() + +`join()`:将数组转换为字符串,返回结果为**转换后的字符串**(不会改变原来的数组)。 + +补充:`join()`方法可以指定一个**字符串**作为参数,这个字符串将会成为数组中元素的**连接符**;如果不指定连接符,则默认使用 `,` 作为连接符,此时和 `toString()的效果是一致的`。 + +语法: + +```javascript + 新的字符串 = 原数组.join(参数); // 参数选填 +``` + +代码举例: + +```javascript + var arr = ["a", "b", "c"]; + + var result1 = arr.join(); // 这里没有指定连接符,所以默认使用 , 作为连接符 + + var result2 = arr.join("-"); // 使用指定的字符串作为连接符 + + console.log(typeof arr); // 打印结果:object + console.log(typeof result1); // 打印结果:string + + console.log("arr =" + JSON.stringify(arr)); + console.log("result1 =" + JSON.stringify(result1)); + console.log("result2 =" + JSON.stringify(result2)); + +``` + +上方代码中,最后三行的打印结果是: + +```javascript +arr =["a","b","c"] +result1 =a,b,c +result2 =a-b-c +``` + +### reverse() + +`reverse()`:反转数组,返回结果为**反转后的数组**(会改变原来的数组)。 + +语法: + +``` + 反转后的数组 = 数组.reverse(); +``` + +举例: + +```javascript + var arr = ["a", "b", "c", "d", "e", "f"]; + + var result = arr.reverse(); // 将数组 arr 进行反转 + + console.log("arr =" + JSON.stringify(arr)); + console.log("result =" + JSON.stringify(result)); +``` + +打印结果: + +```javascript +arr =["f","e","d","c","b","a"] +result =["f","e","d","c","b","a"] +``` + +从打印结果可以看出,原来的数组已经被改变了。 + +## sort()方法 + +> sort()方法要好好理解。所以,我们单独用一大段来讲。 + +`sort()`:对数组的元素进行从小到大来排序(会改变原来的数组)。 + +### sort()方法举例:无参时 + +如果在使用 sort() 方法时不带参,则默认按照**Unicode编码**,从小到大进行排序。 + +**举例1**:(当数组中的元素为字符串时) + +```javascript + var arr1 = ["e", "b", "d", "a", "f", "c"]; + + var result = arr1.sort(); // 将数组 arr1 进行排序 + + console.log("arr1 =" + JSON.stringify(arr1)); + console.log("result =" + JSON.stringify(result)); +``` + +打印结果: + +```javascript + arr1 =["a","b","c","d","e","f"] + result =["a","b","c","d","e","f"] +``` + +**举例2**:(当数组中的元素为数字时) + +```javascript + var arr2 = [5, 2, 11, 3, 4, 1]; + + var result = arr2.sort(); // 将数组 arr2 进行排序 + + console.log("arr2 =" + JSON.stringify(arr2)); + console.log("result =" + JSON.stringify(result)); +``` + +打印结果: + +```javascript + arr2 =[1,11,2,3,4,5] + result =[1,11,2,3,4,5] +``` + +上方的打印结果中,你会发现,使用 sort() 排序后,数字`11`竟然在数字`2`的前面。这是为啥呢?因为上面讲到了,`sort()`方法是按照**Unicode编码**进行排序的。 + +那如果我想让 arr2 里的数字,完全按照从小到大排序,怎么操作呢?继续往下看。 + +### sort()方法举例:带参时 + +如果在 sort()方法中带参,我们就可以**自定义**排序规则。具体做法如下: + +我们可以在sort()添加一个回调函数,来指定排序规则。回调函数中需要定义两个形参,浏览器将会分别使用数组中的元素作为实参去调用回调函数 + +浏览器根据回调函数的返回值来决定元素的排序:(重要) + +- 如果返回一个大于0的值,则元素会交换位置 + +- 如果返回一个小于0的值,则元素位置不变 + +- 如果返回一个0,则认为两个元素相等,则不交换位置 + +**代码举例**: + +```javascript + var arr3 = [5, 2, 11, 3, 4, 1]; + + // 自定义排序规则 + var result = arr3.sort(function(a, b) { + if (a > b) { // 如果 a 大于 b,则交换 a 和 b 的位置 + return 1; + } else if (a < b) { // 如果 a 小于 b,则位置不变 + return -1; + } else { // 如果 a 等于 b,则位置不变 + return 0; + } + }); + + console.log("arr3 =" + JSON.stringify(arr3)); + console.log("result =" + JSON.stringify(result)); + ``` + +打印结果: + +```javascript + arr3 =[1,2,3,4,5,11] + result =[1,2,3,4,5,11] +``` + +上方代码的写法太啰嗦了,其实也可以简化为如下写法: + +**代码优化**:(冒泡排序) + +```javascript + var arr3 = [5, 2, 11, 3, 4, 1]; + + // 自定义排序规则 + var result = arr3.sort(function(a, b) { + return a - b; // 升序排列 + // return b - a; // 降序排列 + }); + + console.log("arr3 =" + JSON.stringify(arr3)); + console.log("result =" + JSON.stringify(result)); +``` + +打印结果: + +```javascript + arr3 =[1,2,3,4,5,11] + result =[1,2,3,4,5,11] +``` + + ## 数组的遍历 遍历数组即:获取并操作数组中的每一个元素。在我们的实战开发中,使用得非常频繁。 @@ -154,12 +545,10 @@ PS:这几个方法**不会修改原数组**。 ![](http://img.smyhvae.com/20180124_2008.png) - ### forEach() 遍历 > `forEach()` 这种遍历方法只支持IE8以上的浏览器。IE8及以下的浏览器均不支持该方法。所以如果需要兼容IE8,则不要使用forEach,改为使用for循环来遍历即可。 - forEach()方法需要一个函数作为参数。这种函数,是由我们创建但是不由我们调用的,我们称为回调函数。 数组中有几个元素,该回调函数就会执行几次。执行完毕后,浏览器会将遍历到的元素。 @@ -204,7 +593,6 @@ obj:王一,王二,王三 ---------- ``` - 注意,forEach() 的返回值是 undefined。也就是说,它没有返回值。如果你尝试 `tempArry = arr.forEach()`这种方式来接收,是达不到效果的。 ### filter() @@ -255,12 +643,13 @@ obj:王一,王二,王三 ![](http://img.smyhvae.com/20180126_1410.png) - ### map()方法 解释:对数组中每一项运行回调函数,返回该函数的结果,组成的新数组(返回的是**加工之后**的新数组)。 -比如说,有一个已知的数组arr1,我要求让arr1中的每个素加10,这里就可以用到map方法。举例: +**举例1**:(拷贝的过程中改变数组元素的值) + +有一个已知的数组arr1,我要求让arr1中的每个元素的值都加10,这里就可以用到 map 方法。代码举例: ```javascript var arr1 = [1, 3, 6, 2, 5, 6]; @@ -276,24 +665,30 @@ obj:王一,王二,王三 ![](http://img.smyhvae.com/20180402_0938.png) -举例2: +**举例2**:【重要案例】 + +将A数组中某个属性的值,存储到B数组中。代码举例: ```javascript - var arr1 = ["千古", "宿敌", "南山忆", "素颜"]; + const arr1 = [ + { name: '千古壹号', age: '28' }, { name: '许嵩', age: '32' } + ]; + const arr2 = arr1.map(item => item.name); // 将数组 arr1 中的 name 属性,存储到 数组 arr2 中 - var arr2 = arr1.map(function (element, index, array) { - return element + "vae"; //给arr1中所有的元素增加字符串"vae",放到arr2中。 - }); - - console.log(arr1); - console.log(arr2); + console.log('arr1:' + JSON.stringify(arr1)); + console.log('arr2:' + JSON.stringify(arr2)); ``` -结果: +打印结果: -![](http://img.smyhvae.com/20180126_1425.png) +``` + arr1:[{"name":"千古壹号","age":"28"},{"name":"许嵩","age":"32"}] + arr2:["千古壹号","许嵩"] +``` + +map的应用场景,主要就是以上两种。 ### every()方法 @@ -327,6 +722,387 @@ obj:王一,王二,王三 解释:对数组中每一项运行回调函数,只要有一项返回true,则停止遍历,此方法返回true。 + +## 数组的其他方法 + +### indexOf() 和 lastIndexOf():获取数据的索引 + +**语法**: + +```javascript + 索引值 = 数组.indexOf(value); + + 索引值 = 数组.lastIndexOf(value); +``` + +**解释**: + +- indexOf(value):从前往后索引,获取 value 在数组中的第一个下标。 + +- lastIndexOf(value) :从后往前索引,获取 value 在数组中的最后一个下标。 + +**作用**: + +利用这个方法,我们可以判断某个值是否在指定的数组中。**如果没找到则返回`-1`**。 + + **举例1**: + +```javascript + var arr = ["a","b","c","d","e","d","c"]; + + console.log(arr.indexOf("c")); //从前往后,找第一个"c"在哪个位置 + console.log(arr.lastIndexOf("d")); //从后往前,找第一个"d"在哪个位置 +``` + +打印结果: + +![](http://img.smyhvae.com/20180126_1125.png) + +**举例2**:判断某个值是否在数组中 + +```javascript + var arr = ["29926392220", "29965620629", "28003663436", " ", "28818504366"]; + + var str = [ + {name:"smyh", id: "12334"}, + + {name:"vae", id: "28818504366"} + ]; + + str.filter(item => { + console.log(arr.indexOf(item.id)); + }) + +``` + +### find() + +**语法**: + +```javascript + find(function(item, index, arr){return true}) +``` + +**作用**:找出**第一个**满足「指定条件返回true」的元素。 + +举例: + +```javascript + let arr = [2, 3, 2, 5, 7, 6]; + + let result = arr.find(function (item, index) { + return item > 4; //遍历数组arr,一旦发现有第一个元素大于4,就把这个元素返回 + }); + + console.log(result); //打印结果:5 +``` + +### findIndex() + +**语法**: + +```javascript + findIndex(function(item, index, arr){return true}) +``` + +**作用**:找出**第一个**满足「指定条件返回true」的元素的index。 + +举例: + +> 我们直接把上面的代码中的find方法改成findIndex,来看看效果。 + +```javascript + let arr = [2, 3, 2, 5, 7, 6]; + + let result = arr.findIndex(function (item, index) { + return item > 4; //遍历数组arr,一旦发现有第一个元素大于4,就把这个元素的index返回 + }); + + console.log(result); //打印结果:3 +``` + + +### Array.from() + +**语法**: + +```javascript +array = Array.from(arrayLike) +``` + +**作用**:将**伪数组**或可遍历对象转换为**真数组**。 + +**举例:** + +```html + + + + + + + + + +``` + +上面的布局中,有三个button标签,我们通过`getElementsByTagName`获取到的`btnArray`实际上是**伪数组**,并不是真实的数组: + +![](http://img.smyhvae.com/20180402_1116.png) + +既然`btnArray`是伪数组,它就不能使用数组的一般方法,否则会报错: + +![](http://img.smyhvae.com/20180402_1121.png) + +解决办法:采用`Array.from`方法将`btnArray`这个伪数组转换为真数组即可: + +```javascript + Array.from(btnArray); +``` + +然后就可以使用数组的一般方法了: + +![](http://img.smyhvae.com/20180402_1125.png) + + +**伪数组与真数组的区别**: + +伪数组的原型链中没有 Array.prototype,而真数组的原型链中有 Array.prototype。因此伪数组没有 pop、join等属性。 + +### Array.of() + +**语法**: + +```javascript + Array.of(value1, value2, value3) +``` + +**作用**:将一系列值转换成数组。 + +**举例**: + +```javascript + let arr = Array.of(1, 'abc', true); + console.log(arr); +``` + +## 其他 + +### isArray():判断是否为数组 + +```javascript + 布尔值 = Array.isArray(被检测的值) ; +``` + +以前,我们会通过 `A instanceof B`来判断 A 是否属于 B 类型。但是在数组里,这种 instanceof 方法已经用的不多了,因为有下面isArray()方法。 + + +### toString():转换数组 + +```javascript + 字符串 = 数组.toString(); +``` + +解释:把数组转换成字符串,每一项用`,`分割。 + +### valueOf():返回数组本身 + +```javascript + 数组本身 = 数组.valueOf(); +``` + +这个方法的意义不大。因为我们指直接写数组对象的名字,就已经是数组本身了。 + + +## 数组练习 + +### splice()练习:数组去重 + +代码实现: + +```javascript + //创建一个数组 + var arr = [1, 2, 3, 2, 2, 1, 3, 4, 2, 5]; + + //去除数组中重复的数字 + //获取数组中的每一个元素 + for (var i = 0; i < arr.length; i++) { + //console.log(arr[i]); + /*获取当前元素后的所有元素*/ + for (var j = i + 1; j < arr.length; j++) { + //console.log("---->"+arr[j]); + //判断两个元素的值是否相等 + if (arr[i] == arr[j]) { + //如果相等则证明出现了重复的元素,则删除j对应的元素 + arr.splice(j, 1); + //当删除了当前j所在的元素以后,后边的元素会自动补位 + //此时将不会在比较这个元素吧,我需要在比较一次j所在位置的元素 + //使j自减 + j--; + } + } + } + + console.log(arr); +``` + +### 清空数组 + +清空数组,有以下几种方式: + +```javascript + var array = [1,2,3,4,5,6]; + + array.splice(0); //方式1:删除数组中所有项目 + array.length = 0; //方式2:length属性可以赋值,在其它语言中length是只读 + array = []; //方式3:推荐 +``` + +### 练习1 + +**问题**:将一个字符串数组输出为`|`分割的形式,比如“千古|宿敌|素颜”。使用两种方式实现。 + +答案: + +方式1:(不推荐) + +```javascript + var arr = ["千古","宿敌","素颜"]; + var str = arr[0]; + var separator = "|"; + for(var i = 1;i< arr.length;i++) { + str += separator+arr[i]; //从第1个数组元素开始,每个元素前面加上符号"|" + } + + console.log(str); +``` + +输出结果: + +![](http://img.smyhvae.com/20180126_1336.png) + +不推荐这种方式,因为:由于字符串的不变性,str拼接过多的话,容易导致内存溢出(很多个str都堆放在栈里)。 + +方式2:(推荐。通过array数组自带的api来实现) + +```javascript + var arr = ["千古","宿敌","素颜"]; + + console.log(arr.join("|")); +``` + +结果: + +![](http://img.smyhvae.com/20180126_1339.png) + +### 练习2 + +题目:将一个字符串数组的元素的顺序进行反转,使用两种种方式实现。提示:第i个和第length-i-1个进行交换。 + +答案: + +方式1: + +```javascript + function reverse(array) { + var newArr = []; + for (var i = array.length - 1; i >= 0; i--) { + newArr[newArr.length] = array[i]; + } + return newArr; + } +``` + +方式2:(算法里比较常见的方式) + +```javascript + function reverse(array){ + for(var i=0;i**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**(id:`qianguyihao`)。 diff --git a/03-JavaScript基础/18-内置对象:Date.md b/03-JavaScript基础/16-内置对象:Date.md similarity index 100% rename from 03-JavaScript基础/18-内置对象:Date.md rename to 03-JavaScript基础/16-内置对象:Date.md diff --git a/03-JavaScript基础/16-数组的常见方法.md b/03-JavaScript基础/16-数组的常见方法.md deleted file mode 100644 index 1decd05..0000000 --- a/03-JavaScript基础/16-数组的常见方法.md +++ /dev/null @@ -1,417 +0,0 @@ - -## 前言 - -数组的常见方法如下: - -| 方法 | 描述 | 备注 | -|:-------------|:-------------|:-------------| -| slice() | 从数组中**提取**指定的一个或多个元素,返回结果为**新的数组**| 不会改变原数组| -| splice() | 从数组中**删除**指定的一个或多个元素,返回结果为**新的数组**| 会改变原数组| -| concat() | 连接两个或多个数组,返回结果为**新的数组**| 不会改变原数组| -| join() | 将数组转换为字符串,返回结果为**转换后的字符串**| 不会改变原数组| -| reverse() | 反转数组,返回结果为**反转后的数组**| 会改变原数组| -| sort() | 对数组的元素,默认按照**Unicode编码**,从小到大进行排序| 会改变原数组| - - -## 数组的常见方法 - -### slice() - -`slice()`:从数组中提取指定的一个或者多个元素,返回结果为**新的数组**(不会改变原来的数组)。 - -备注:该方法不会改变原数组,而是将截取到的元素封装到一个新数组中返回。 - -**语法**: - -```javascript - 新数组 = 原数组.slice(开始位置的索引, 结束位置的索引); //注意:包含开始索引,不包含结束索引 -``` - -举例: - -```javascript - var arr = ["a", "b", "c", "d", "e", "f"]; - - var result1 = arr.slice(2); //从第二个值开始提取 - var result2 = arr.slice(-2); //提取最后两个元素 - var result3 = arr.slice(2, 4); //提取从第二个到第四个之间的值(不包括第四个值) - var result4 = arr.slice(4, 2); //空 - - console.log("arr:" + JSON.stringify(arr)); - console.log("result1:" + JSON.stringify(result1)); - console.log("result2:" + JSON.stringify(result2)); - console.log("result3:" + JSON.stringify(result3)); - console.log("result4:" + JSON.stringify(result4)); - -``` - -打印结果: - -```javascript - arr:["a","b","c","d","e","f"] - result1:["c","d","e","f"] - result2:["e","f"] - result3:["c","d"] - result4:[] -``` - - -**补充**: - -很多前端开发人员会用 slice()将伪数组,转化为真数组。写法如下: - -```javascript -array = Array.prototye.slice.call(arrayLike) -或者 -array = [].slice.call(arrayLike) -``` - - -ES6 看不下去这种蹩脚的转化方法,于是出了一个新的 API:(专门用来将伪数组转化成真数组) - -```javascript -array = Array.from(arrayLike) -``` - - -### splice() - -`splice()`:从数组中**删除**指定的一个或多个元素,返回结果为**新的数组**(会改变原来的数组,会将指定元素从原数组中删除)。 - -语法: - -```javascript - 新数组 = 原数组.splice(起始索引index, 需要删除的个数, 第三个参数, 第四个参数...); -``` - -上方语法中,第三个及之后的参数,表示:向原数组中添加新的元素,这些元素将会自动插入到开始位置索引的前面。 - -举例1: - -```javascript - var arr1 = ["a", "b", "c", "d", "e", "f"]; - var result1 = arr1.splice(1); //从第index为1的位置开始,删除元素 - - console.log("arr1:" + JSON.stringify(arr1)); - console.log("result1:" + JSON.stringify(result1)); - - console.log("-----------------------"); - - var arr2 = ["a", "b", "c", "d", "e", "f"]; - var result2 = arr2.splice(-2); //从第一个位置开始,删除元素 - - console.log("arr2:" + JSON.stringify(arr2)); - console.log("result2:" + JSON.stringify(result2)); - - console.log("-----------------------"); - - var arr3 = ["a", "b", "c", "d", "e", "f"]; - var result3 = arr3.splice(1, 3); //从第index为1的位置开始删除元素,一共删除三个元素 - - console.log("arr3:" + JSON.stringify(arr3)); - console.log("result3:" + JSON.stringify(result3)); - - console.log("-----------------------"); -``` - -打印结果: - -```javascript -arr1:["a"] -result1:["b","c","d","e","f"] ------------------------ - -arr2:["a","b","c","d"] -result2:["e","f"] ------------------------ - -arr3:["a","e","f"] -result3:["b","c","d"] ------------------------ -``` - -举例2:(我们来看看**第三个参数**的用法) - -```javascript -var arr4 = ["a", "b", "c", "d", "e", "f"]; - -//从第index为1的位置开始删除元素,一共删除三个元素。并且在 index=1 的前面追加两个元素 -var result4 = arr4.splice(1, 3, "千古壹号", "vae"); - -console.log("arr4:" + JSON.stringify(arr4)); -console.log("result4:" + JSON.stringify(result4)); -``` - -打印结果: - -```javascript -arr4:["a","千古壹号","vae","e","f"] -result4:["b","c","d"] -``` - -### concat() - -`concat()`:连接两个或多个数组,返回结果为**新的数组**。(不会改变原数组) - -语法: - -```javascript - 新数组 = 数组1.concat(数组2, 数组3 ...); - -``` - -举例: - -```javascript - var arr1 = [1, 2, 3]; - var arr2 = ["a", "b", "c"]; - var arr3 = ["千古壹号", "vae"]; - - var result1 = arr1.concat(arr2); - - var result2 = arr2.concat(arr1, arr3); - - console.log("arr1 =" + JSON.stringify(arr1)); - console.log("arr2 =" + JSON.stringify(arr2)); - console.log("arr3 =" + JSON.stringify(arr3)); - - console.log("result1 =" + JSON.stringify(result1)); - console.log("result2 =" + JSON.stringify(result2)); -``` - -打印结果: - -```javascript -arr1 =[1,2,3] -arr2 =["a","b","c"] -arr3 =["千古壹号","vae"] - -result1 =[1,2,3,"a","b","c"] -result2 =["a","b","c",1,2,3,"千古壹号","vae"] -``` - -从打印结果中可以看到,原数组并没有被修改。 - - -### join() - -`join()`:将数组转换为字符串,返回结果为**转换后的字符串**(不会改变原来的数组)。 - -补充:`join()`方法可以指定一个**字符串**作为参数,这个字符串将会成为数组中元素的**连接符**;如果不指定连接符,则默认使用 `,` 作为连接符,此时和 `toString()的效果是一致的`。 - -语法: - -```javascript - 新的字符串 = 原数组.join(参数); // 参数选填 -``` - -代码举例: - -```javascript - var arr = ["a", "b", "c"]; - - var result1 = arr.join(); // 这里没有指定连接符,所以默认使用 , 作为连接符 - - var result2 = arr.join("-"); // 使用指定的字符串作为连接符 - - console.log(typeof arr); // 打印结果:object - console.log(typeof result1); // 打印结果:string - - console.log("arr =" + JSON.stringify(arr)); - console.log("result1 =" + JSON.stringify(result1)); - console.log("result2 =" + JSON.stringify(result2)); - -``` - -上方代码中,最后三行的打印结果是: - -```javascript -arr =["a","b","c"] -result1 =a,b,c -result2 =a-b-c -``` - -### reverse() - -`reverse()`:反转数组,返回结果为**反转后的数组**(会改变原来的数组)。 - -语法: - -``` - 反转后的数组 = 数组.reverse(); -``` - -举例: - -```javascript - var arr = ["a", "b", "c", "d", "e", "f"]; - - var result = arr.reverse(); // 将数组 arr 进行反转 - - console.log("arr =" + JSON.stringify(arr)); - console.log("result =" + JSON.stringify(result)); -``` - -打印结果: - -```javascript -arr =["f","e","d","c","b","a"] -result =["f","e","d","c","b","a"] -``` - -从打印结果可以看出,原来的数组已经被改变了。 - -## sort()方法 - -> sort()方法要好好理解。所以,我们单独用一大段来讲。 - -`sort()`:对数组的元素进行从小到大来排序(会改变原来的数组)。 - -### sort()方法举例:无参时 - -如果在使用 sort() 方法时不带参,则默认按照**Unicode编码**,从小到大进行排序。 - -**举例1**:(当数组中的元素为字符串时) - -```javascript - var arr1 = ["e", "b", "d", "a", "f", "c"]; - - var result = arr1.sort(); // 将数组 arr1 进行排序 - - console.log("arr1 =" + JSON.stringify(arr1)); - console.log("result =" + JSON.stringify(result)); -``` - -打印结果: - -```javascript - arr1 =["a","b","c","d","e","f"] - result =["a","b","c","d","e","f"] -``` - -**举例2**:(当数组中的元素为数字时) - -```javascript - var arr2 = [5, 2, 11, 3, 4, 1]; - - var result = arr2s.sort(); // 将数组 arr2 进行排序 - - console.log("arr2 =" + JSON.stringify(arr2)); - console.log("result =" + JSON.stringify(result)); -``` - -打印结果: - -```javascript - arr2 =[1,11,2,3,4,5] - result =[1,11,2,3,4,5] -``` - -上方的打印结果中,你会发现,使用 sort() 排序后,数字`11`竟然在数字`2`的前面。这是为啥呢?因为上面讲到了,`sort()`方法是按照**Unicode编码**进行排序的。 - -那如果我想让 arr2 里的数字,完全按照从小到大排序,怎么操作呢?继续往下看。 - -### sort()方法举例:带参时 - -如果在 sort()方法中带参,我们就可以**自定义**排序规则。具体做法如下: - -我们可以在sort()添加一个回调函数,来指定排序规则。回调函数中需要定义两个形参,浏览器将会分别使用数组中的元素作为实参去调用回调函数 - -浏览器根据回调函数的返回值来决定元素的排序:(重要) - -- 如果返回一个大于0的值,则元素会交换位置 - -- 如果返回一个小于0的值,则元素位置不变 - -- 如果返回一个0,则认为两个元素相等,则不交换位置 - -**代码举例**: - -```javascript - var arr3 = [5, 2, 11, 3, 4, 1]; - - // 自定义排序规则 - var result = arr3.sort(function(a, b) { - if (a > b) { // 如果 a 大于 b,则交换 a 和 b 的位置 - return 1; - } else if (a < b) { // 如果 a 小于 b,则位置不变 - return -1; - } else { // 如果 a 等于 b,则位置不变 - return 0; - } - }); - - console.log("arr3 =" + JSON.stringify(arr3)); - console.log("result =" + JSON.stringify(result)); - ``` - -打印结果: - -```javascript - arr3 =[1,2,3,4,5,11] - result =[1,2,3,4,5,11] -``` - -上方代码的写法太啰嗦了,其实也可以简化为如下写法: - -**代码优化**:(冒泡排序) - -```javascript - var arr3 = [5, 2, 11, 3, 4, 1]; - - // 自定义排序规则 - var result = arr3.sort(function(a, b) { - return a - b; // 升序排列 - // return b - a; // 降序排列 - }); - - console.log("arr3 =" + JSON.stringify(arr3)); - console.log("result =" + JSON.stringify(result)); -``` - -打印结果: - -```javascript - arr3 =[1,2,3,4,5,11] - result =[1,2,3,4,5,11] -``` - -## 练习 - -### splice()练习:数组去重 - -代码实现: - -```javascript - //创建一个数组 - var arr = [1, 2, 3, 2, 2, 1, 3, 4, 2, 5]; - - //去除数组中重复的数字 - //获取数组中的每一个元素 - for (var i = 0; i < arr.length; i++) { - //console.log(arr[i]); - /*获取当前元素后的所有元素*/ - for (var j = i + 1; j < arr.length; j++) { - //console.log("---->"+arr[j]); - //判断两个元素的值是否相等 - if (arr[i] == arr[j]) { - //如果相等则证明出现了重复的元素,则删除j对应的元素 - arr.splice(j, 1); - //当删除了当前j所在的元素以后,后边的元素会自动补位 - //此时将不会在比较这个元素吧,我需要在比较一次j所在位置的元素 - //使j自减 - j--; - } - } - } - - console.log(arr); -``` - -## 我的公众号 - -想学习**代码之外的技能**?不妨关注我的微信公众号:**千古壹号**(id:`qianguyihao`)。 - -扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外: - -![](http://img.smyhvae.com/20190101.png) diff --git a/03-JavaScript基础/19-内置对象:Math.md b/03-JavaScript基础/17-内置对象:Math.md similarity index 100% rename from 03-JavaScript基础/19-内置对象:Math.md rename to 03-JavaScript基础/17-内置对象:Math.md diff --git a/03-JavaScript基础/17-数组的其他方法.md b/03-JavaScript基础/17-数组的其他方法.md deleted file mode 100644 index ed4333f..0000000 --- a/03-JavaScript基础/17-数组的其他方法.md +++ /dev/null @@ -1,374 +0,0 @@ - -## 前言 - -数组的其他方法如下: - -| 方法 | 描述 | 备注 | -|:-------------|:-------------|:-------------| -| indexOf(value) | 从前往后索引,获取 value 在数组中的第一个下标 | | -| lastIndexOf(value) | 从后往前索引,获取 value 在数组中的最后一个下标 | | -| find(function()) | 找出**第一个**满足「指定条件返回true」的元素。 | | -| findIndex(function()) | 找出**第一个**满足「指定条件返回true」的元素的index | | -| Array.from(arrayLike) | 将**伪数组**转化为**真数组**| | -| Array.of(value1, value2, value3) | 将**一系列值**转换成数组。| | - -## 数组的其他方法 - -### indexOf() 和 lastIndexOf():获取数据的索引 - -**语法**: - -```javascript - 索引值 = 数组.indexOf(value); - - 索引值 = 数组.lastIndexOf(value); -``` - -**解释**: - -- indexOf(value):从前往后索引,获取 value 在数组中的第一个下标。 - -- lastIndexOf(value) :从后往前索引,获取 value 在数组中的最后一个下标。 - -**作用**: - -利用这个方法,我们可以判断某个值是否在指定的数组中。**如果没找到则返回`-1`**。 - - **举例1**: - -```javascript - var arr = ["a","b","c","d","e","d","c"]; - - console.log(arr.indexOf("c")); //从前往后,找第一个"c"在哪个位置 - console.log(arr.lastIndexOf("d")); //从后往前,找第一个"d"在哪个位置 -``` - -打印结果: - -![](http://img.smyhvae.com/20180126_1125.png) - -**举例2**:判断某个值是否在数组中 - -```javascript - var arr = ["29926392220", "29965620629", "28003663436", " ", "28818504366"]; - - var str = [ - {name:"smyh", id: "12334"}, - - {name:"vae", id: "28818504366"} - ]; - - str.filter(item => { - console.log(arr.indexOf(item.id)); - }) - -``` - -### find() - -**语法**: - - -```javascript - find(function(item, index, arr){return true}) -``` - -**作用**:找出**第一个**满足「指定条件返回true」的元素。 - -举例: - -```javascript - let arr = [2, 3, 2, 5, 7, 6]; - - let result = arr.find(function (item, index) { - return item > 4; //遍历数组arr,一旦发现有第一个元素大于4,就把这个元素返回 - }); - - console.log(result); //打印结果:5 -``` - -### findIndex() - -**语法**: - -```javascript - findIndex(function(item, index, arr){return true}) -``` - -**作用**:找出**第一个**满足「指定条件返回true」的元素的index。 - -举例: - -> 我们直接把上面的代码中的find方法改成findIndex,来看看效果。 - -```javascript - let arr = [2, 3, 2, 5, 7, 6]; - - let result = arr.findIndex(function (item, index) { - return item > 4; //遍历数组arr,一旦发现有第一个元素大于4,就把这个元素的index返回 - }); - - console.log(result); //打印结果:3 -``` - - -### Array.from() - -**语法**: - -```javascript -array = Array.from(arrayLike) -``` - -**作用**:将**伪数组**或可遍历对象转换为**真数组**。 - -**举例:** - -```html - - - - - - - - - -``` - -上面的布局中,有三个button标签,我们通过`getElementsByTagName`获取到的`btnArray`实际上是**伪数组**,并不是真实的数组: - -![](http://img.smyhvae.com/20180402_1116.png) - -既然`btnArray`是伪数组,它就不能使用数组的一般方法,否则会报错: - -![](http://img.smyhvae.com/20180402_1121.png) - -解决办法:采用`Array.from`方法将`btnArray`这个伪数组转换为真数组即可: - -```javascript - Array.from(btnArray); -``` - -然后就可以使用数组的一般方法了: - -![](http://img.smyhvae.com/20180402_1125.png) - - -**伪数组与真数组的区别**: - -伪数组的原型链中没有 Array.prototype,而真数组的原型链中有 Array.prototype。因此伪数组没有 pop、join等属性。 - -### Array.of() - -**语法**: - -```javascript - Array.of(value1, value2, value3) -``` - -**作用**:将一系列值转换成数组。 - -**举例**: - -```javascript - //Array.of(value1, value2, value3) : 将一系列值转换成数组 - let arr = Array.of(1, 'abc', true); - console.log(arr); -``` - -## 其他 - -### isArray():判断是否为数组 - -```javascript - 布尔值 = Array.isArray(被检测的值) ; -``` - -以前,我们会通过 `A instanceof B`来判断 A 是否属于 B 类型。但是在数组里,这种 instanceof 方法已经用的不多了,因为有下面isArray()方法。 - - -### toString():转换数组 - -```javascript - 字符串 = 数组.toString(); -``` - -解释:把数组转换成字符串,每一项用`,`分割。 - -### valueOf():返回数组本身 - -```javascript - 数组本身 = 数组.valueOf(); -``` - -这个方法的意义不大。因为我们指直接写数组对象的名字,就已经是数组本身了。 - - -## 清空数组 - -清空数组,有以下几种方式: - -```javascript - var array = [1,2,3,4,5,6]; - - array.splice(0); //方式1:删除数组中所有项目 - array.length = 0; //方式2:length属性可以赋值,在其它语言中length是只读 - array = []; //方式3:推荐 -``` - -## 数组练习 - -### 练习1 - -**问题**:将一个字符串数组输出为`|`分割的形式,比如“千古|宿敌|素颜”。使用两种方式实现。 - -答案: - -方式1:(不推荐) - -```javascript - var arr = ["千古","宿敌","素颜"]; - var str = arr[0]; - var separator = "|"; - for(var i = 1;i< arr.length;i++) { - str += separator+arr[i]; //从第1个数组元素开始,每个元素前面加上符号"|" - } - - console.log(str); -``` - -输出结果: - -![](http://img.smyhvae.com/20180126_1336.png) - -不推荐这种方式,因为:由于字符串的不变性,str拼接过多的话,容易导致内存溢出(很多个str都堆放在栈里)。 - -方式2:(推荐。通过array数组自带的api来实现) - -```javascript - var arr = ["千古","宿敌","素颜"]; - - console.log(arr.join("|")); -``` - -结果: - -![](http://img.smyhvae.com/20180126_1339.png) - -### 练习2 - -题目:将一个字符串数组的元素的顺序进行反转,使用两种种方式实现。提示:第i个和第length-i-1个进行交换。 - -答案: - -方式1: - -```javascript - function reverse(array) { - var newArr = []; - for (var i = array.length - 1; i >= 0; i--) { - newArr[newArr.length] = array[i]; - } - return newArr; - } -``` - -方式2:(算法里比较常见的方式) - -```javascript - function reverse(array){ - for(var i=0;i 下面讲的这几个方法,都是给数组的实例用的。 -> 下面提到的数组的这五个方法,更详细的内容,可以看《03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md》、《03-JavaScript基础/17-数组的其他方法.md》。 +> 下面提到的数组的这五个方法,更详细的内容,可以看《03-JavaScript基础/15-数组的常见方法.md》 **方法1**: diff --git a/10-ES6/09-ES6:字符串、数组、对象的扩展.md b/10-ES6/09-ES6:字符串、数组、对象的扩展.md index b8a6777..f84fec3 100644 --- a/10-ES6/09-ES6:字符串、数组、对象的扩展.md +++ b/10-ES6/09-ES6:字符串、数组、对象的扩展.md @@ -37,7 +37,7 @@ ES6中的字符串扩展,用得少,而且逻辑相对简单。如下: ![](http://img.smyhvae.com/20180402_1050.png) -## 数值的扩展 +## Number 的扩展 - 二进制与八进制数值表示法: 二进制用`0b`, 八进制用`0o`。 diff --git a/18-推荐链接/03-GitHub项目推荐.md b/18-推荐链接/03-GitHub项目推荐.md index 454c3f4..7aea778 100644 --- a/18-推荐链接/03-GitHub项目推荐.md +++ b/18-推荐链接/03-GitHub项目推荐.md @@ -1,5 +1,9 @@ +### 2019-03-01 + +- TypeScript 教程: + ### 2019-04-03 - 收集优质的中文前端博客: