From 5dbfc370ae90e37c245ccd347fac41145868b2c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=88=B4=E4=BF=8A=E9=94=8B?= <95995809+zzzzzzz123000@users.noreply.github.com> Date: Tue, 18 Oct 2022 20:25:03 +0800 Subject: [PATCH] =?UTF-8?q?=E7=AC=AC=E4=B8=89=E6=AC=A1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...44\270\232--\346\225\260\347\273\204.html" | 90 +++++ ...\350\256\260--\346\225\260\347\273\204.md" | 323 ++++++++++++++++++ 2 files changed, 413 insertions(+) create mode 100644 "25\346\210\264\344\277\212\351\224\213/\344\275\234\344\270\232/2022.10.17\344\275\234\344\270\232--\346\225\260\347\273\204.html" create mode 100644 "25\346\210\264\344\277\212\351\224\213/\347\254\224\350\256\260/2022.10.17\347\254\224\350\256\260--\346\225\260\347\273\204.md" diff --git "a/25\346\210\264\344\277\212\351\224\213/\344\275\234\344\270\232/2022.10.17\344\275\234\344\270\232--\346\225\260\347\273\204.html" "b/25\346\210\264\344\277\212\351\224\213/\344\275\234\344\270\232/2022.10.17\344\275\234\344\270\232--\346\225\260\347\273\204.html" new file mode 100644 index 0000000..8c1ada1 --- /dev/null +++ "b/25\346\210\264\344\277\212\351\224\213/\344\275\234\344\270\232/2022.10.17\344\275\234\344\270\232--\346\225\260\347\273\204.html" @@ -0,0 +1,90 @@ + + + + + + + Document + + + + + \ No newline at end of file diff --git "a/25\346\210\264\344\277\212\351\224\213/\347\254\224\350\256\260/2022.10.17\347\254\224\350\256\260--\346\225\260\347\273\204.md" "b/25\346\210\264\344\277\212\351\224\213/\347\254\224\350\256\260/2022.10.17\347\254\224\350\256\260--\346\225\260\347\273\204.md" new file mode 100644 index 0000000..3986743 --- /dev/null +++ "b/25\346\210\264\344\277\212\351\224\213/\347\254\224\350\256\260/2022.10.17\347\254\224\350\256\260--\346\225\260\347\273\204.md" @@ -0,0 +1,323 @@ +# 1.数组 + +## 1.1获取最后一个元素(at) + +```javascript +let fruits = ["Apple", "Orange", "Plum"]; + +// 与 fruits[fruits.length-1] 相同 +alert( fruits.at(-1) ); // Plum +``` + +- 如果 `i >= 0`,则与 `arr[i]` 完全相同。 +- 对于 `i` 为负数的情况,它则从数组的尾部向前数。 + +## 1.2 pop/push,shift/unshift 方法 + +- `push` 在末端添加一个元素. +- `shift` 取出队列首端的一个元素,整个队列往前移,这样原先排第二的元素现在排在了第一。 +- `pop` 从末端取出一个元素. + +### 1.2.1作用于数组末端的方法: + +#### 1.2.1 .1 pop + +取出并返回数组的最后一个元素: + +```javascript +let fruits = ["Apple", "Orange", "Pear"]; + +alert( fruits.pop() ); // 移除 "Pear" 然后 alert 显示出来 + +alert( fruits ); // Apple, Orange + +//fruits.pop() 和 fruits.at(-1) 都返回数组的最后一个元素,但 fruits.pop() 同时也删除了数组的最后一个元素,进而修改了原数组。 +``` + + + +#### 1.2.1.2 push + +在数组末端添加元素: + +```javascript +let fruits = ["Apple", "Orange"]; + +fruits.push("Pear"); + +alert( fruits ); // Apple, Orange, Pear + +//调用 fruits.push(...) 与 fruits[fruits.length] = ... 是一样的。 +``` + +### 1.2.2作用于数组首端的方法: + +#### 1.2.2.1 shift + +取出数组的第一个元素并返回它: + +```javascript +let fruits = ["Apple", "Orange", "Pear"]; + +alert( fruits.shift() ); // 移除 Apple 然后 alert 显示出来 + +alert( fruits ); // Orange, Pear +``` + +#### 1.2.2.2 unshift + +在数组的首端添加元素: + +```javascript +let fruits = ["Orange", "Pear"]; + +fruits.unshift('Apple'); + +alert( fruits ); // Apple, Orange, Pear +``` + +`push` 和 `unshift` 方法都可以一次添加多个元素: + +```javascript +let fruits = ["Apple"]; + +fruits.push("Orange", "Peach"); +fruits.unshift("Pineapple", "Lemon"); + +// ["Pineapple", "Lemon", "Apple", "Orange", "Peach"] +alert( fruits ); +``` + +## 1.3length + +`length` 属性的一个有意思的点是它是可写的。 + +如果我们手动增加它,则不会发生任何有趣的事儿。但是如果我们减少它,数组就会被截断。该过程是不可逆的, + +## 1.4[toString](https://zh.javascript.info/array#tostring) + +数组有自己的 `toString` 方法的实现,会返回以逗号隔开的元素列表。 + +## 1.5总结 + +## + +数组是一种特殊的对象,适用于存储和管理有序的数据项。 + +声明: + +```javascript +// 方括号 (常见用法) +let arr = [item1, item2...]; + +// new Array (极其少见) +let arr = new Array(item1, item2...); +``` + +调用 `new Array(number)` 会创建一个给定长度的数组,但不含有任何项。 + +- `length` 属性是数组的长度,准确地说,它是数组最后一个数字索引值加一。它由数组方法自动调整。 +- 如果我们手动缩短 `length`,那么数组就会被截断。 + +获取元素: + +- 你可以通过元素的索引获取元素,例如 `arr[0]` +- 我们也可以使用允许负索引的 `at(i)` 方法。对于负值的 `i`,它会从数组的末尾往回数。如果 `i >= 0`,它的工作方式与 `arr[i]` 相同。 + +我们可以通过下列操作以双端队列的方式使用数组: + +- `push(...items)` 在末端添加 `items` 项。 +- `pop()` 从末端移除并返回该元素。 +- `shift()` 从首端移除并返回该元素。 +- `unshift(...items)` 从首端添加 `items` 项。 + +遍历数组的元素: + +- `for (let i=0; i` 和 `<` 等运算符),因为它们不会对数组进行特殊处理。它们通常会像处理任意对象那样处理数组,这通常不是我们想要的。 + +但是,我们可以使用 `for..of` 循环来逐项比较数组。 + +# 2.数组方法 + +## 1.1添加/移除数组 + +### 1.1.1 splice + +arr.splice 它可以做所有事情:添加,删除和插入元素。 + +```javascript +arr.splice(start[, deleteCount, elem1, ..., elemN]) +``` + +它从索引 `start` 开始修改 `arr`:删除 `deleteCount` 个元素并在当前位置插入 `elem1, ..., elemN`。最后返回被删除的元素所组成的数组 + +```javascript +let arr = ["I", "study", "JavaScript"]; + +arr.splice(1, 1); // 从索引 1 开始删除 1 个元素 + +alert( arr ); // ["I", "JavaScript"] +//当只填写了 splice 的 start 参数时,将删除从索引 start 开始的所有数组项 +``` + +删除了 3 个元素,并用另外两个元素替换它们: + +```javascript +let arr = ["I", "study", "JavaScript", "right", "now"]; + +// 删除数组的前三项,并使用其他内容代替它们 +arr.splice(0, 3, "Let's", "dance"); + +alert( arr ) // 现在 ["Let's", "dance", "right", "now"] +``` + +`splice` 返回了被删除的元素所组成的数组: + +```javascript +let arr = ["I", "study", "JavaScript", "right", "now"]; + +// 删除前两个元素 +let removed = arr.splice(0, 2); + +alert( removed ); // "I", "study" <-- 被从数组中删除了的元素 +``` + +将 `deleteCount` 设置为 `0`,`splice` 方法就能够插入元素而不用删除任何元素: + +```javascript +let arr = ["I", "study", "JavaScript"]; + +// 从索引 2 开始 +// 删除 0 个元素 +// 然后插入 "complex" 和 "language" +arr.splice(2, 0, "complex", "language"); + +alert( arr ); // "I", "study", "complex", "language", "JavaScript" +``` + +在这里和其他数组方法中,负向索引都是被允许的。它们从数组末尾计算位置,如下所示 + +```javascript +let arr = [1, 2, 5]; + +// 从索引 -1(尾端前一位) +// 删除 0 个元素, +// 然后插入 3 和 4 +arr.splice(-1, 0, 3, 4); + +alert( arr ); // 1,2,3,4,5 +``` + +## [转换数组](https://zh.javascript.info/array-methods#zhuan-huan-shu-zu) + +让我们继续学习进行数组转换和重新排序的方法。 + +### [map](https://zh.javascript.info/array-methods#map) + +[arr.map](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/Array/map) 方法是最有用和经常使用的方法之一。 + +它对数组的每个元素都调用函数,并返回结果数组。 + +语法: + +```javascript +let result = arr.map(function(item, index, array) { + // 返回新值而不是当前元素 +}) +``` + +例如,在这里我们将每个元素转换为它的字符串长度: + +```javascript +let lengths = ["Bilbo", "Gandalf", "Nazgul"].map(item => item.length); +alert(lengths); // 5,7,6 +``` + +### [sort(fn)](https://zh.javascript.info/array-methods#sortfn) + +[arr.sort](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) 方法对数组进行 **原位(in-place)** 排序,更改元素的顺序。(译注:原位是指在此数组内,而非生成一个新数组。) + +它还返回排序后的数组,但是返回值通常会被忽略,因为修改了 `arr` 本身。 + +语法: + +```javascript +let arr = [ 1, 2, 15 ]; + +// 该方法重新排列 arr 的内容 +arr.sort(); + +alert( arr ); // 1, 15, 2 +``` + +### [reverse](https://zh.javascript.info/array-methods#reverse) + +[arr.reverse](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/Array/reverse) 方法用于颠倒 `arr` 中元素的顺序。 + +例如: + +```javascript +let arr = [1, 2, 3, 4, 5]; +arr.reverse(); + +alert( arr ); // 5,4,3,2,1 +``` + +它也会返回颠倒后的数组 `arr`。 + +### [split 和 join](https://zh.javascript.info/array-methods#split-he-join) + +举一个现实生活场景的例子。我们正在编写一个消息应用程序,并且该人员输入以逗号分隔的接收者列表:`John, Pete, Mary`。但对我们来说,名字数组比单个字符串舒适得多。怎么做才能获得这样的数组呢? + +[str.split(delim)](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/String/split) 方法可以做到。它通过给定的分隔符 `delim` 将字符串分割成一个数组。 + +在下面的例子中,我们用“逗号后跟着一个空格”作为分隔符: + +```javascript +let names = 'Bilbo, Gandalf, Nazgul'; + +let arr = names.split(', '); + +for (let name of arr) { + alert( `A message to ${name}.` ); // A message to Bilbo(和其他名字) +} +``` + +`split` 方法有一个可选的第二个数字参数 —— 对数组长度的限制。如果提供了,那么额外的元素会被忽略。但实际上它很少使用: + +```javascript +let arr = 'Bilbo, Gandalf, Nazgul, Saruman'.split(', ', 2); + +alert(arr); // Bilbo, Gandalf +``` + +### [reduce/reduceRight](https://zh.javascript.info/array-methods#reducereduceright) + +当我们需要遍历一个数组时 —— 我们可以使用 `forEach`,`for` 或 `for..of`。 + +当我们需要遍历并返回每个元素的数据时 —— 我们可以使用 `map`。 + +[arr.reduce](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce) 方法和 [arr.reduceRight](https://developer.mozilla.org/zh/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight) 方法和上面的种类差不多,但稍微复杂一点。它们用于根据数组计算单个值。 + +语法是: + +```javascript +let value = arr.reduce(function(accumulator, item, index, array) { + // ... +}, [initial]); +``` + +该函数一个接一个地应用于所有数组元素,并将其结果“搬运(carry on)”到下一个调用。 + +参数: + +- `accumulator` —— 是上一个函数调用的结果,第一次等于 `initial`(如果提供了 `initial` 的话)。 +- `item` —— 当前的数组元素。 +- `index` —— 当前索引。 +- `arr` —— 数组本身。 + +应用函数时,上一个函数调用的结果将作为第一个参数传递给下一个函数。 \ No newline at end of file -- Gitee