From aee670cb9b47373ea96371dbc4344b4e2227ba81 Mon Sep 17 00:00:00 2001 From: ruanyf Date: Thu, 12 May 2016 07:44:57 +0800 Subject: [PATCH] =?UTF-8?q?doc(array):=20=E5=88=A0=E9=99=A4=E6=95=B0?= =?UTF-8?q?=E7=BB=84=E6=8E=A8=E5=AF=BC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/array.md | 104 -------------------------------------------------- 1 file changed, 104 deletions(-) diff --git a/docs/array.md b/docs/array.md index 73f4621..ddcc7cf 100644 --- a/docs/array.md +++ b/docs/array.md @@ -497,107 +497,3 @@ for (let i of arr) { 由于空位的处理规则非常不统一,所以建议避免出现空位。 -## 数组推导 - -数组推导(array comprehension)提供简洁写法,允许直接通过现有数组生成新数组。这项功能本来是要放入ES6的,但是TC39委员会想继续完善这项功能,让其支持所有数据结构(内部调用iterator对象),不像现在只支持数组,所以就把它推迟到了ES7。Babel转码器已经支持这个功能。 - -```javascript -var a1 = [1, 2, 3, 4]; -var a2 = [for (i of a1) i * 2]; - -a2 // [2, 4, 6, 8] -``` - -上面代码表示,通过`for...of`结构,数组`a2`直接在`a1`的基础上生成。 - -注意,数组推导中,`for...of`结构总是写在最前面,返回的表达式写在最后面。 - -`for...of`后面还可以附加`if`语句,用来设定循环的限制条件。 - -```javascript -var years = [ 1954, 1974, 1990, 2006, 2010, 2014 ]; - -[for (year of years) if (year > 2000) year]; -// [ 2006, 2010, 2014 ] - -[for (year of years) if (year > 2000) if(year < 2010) year]; -// [ 2006] - -[for (year of years) if (year > 2000 && year < 2010) year]; -// [ 2006] -``` - -上面代码表明,`if`语句要写在`for...of`与返回的表达式之间,而且可以多个`if`语句连用。 - -下面是另一个例子。 - -```javascript -var customers = [ - { - name: 'Jack', - age: 25, - city: 'New York' - }, - { - name: 'Peter', - age: 30, - city: 'Seattle' - } -]; - -var results = [ - for (c of customers) - if (c.city == "Seattle") - { name: c.name, age: c.age } -]; -results // { name: "Peter", age: 30 } -``` - -数组推导可以替代`map`和`filter`方法。 - -```javascript -[for (i of [1, 2, 3]) i * i]; -// 等价于 -[1, 2, 3].map(function (i) { return i * i }); - -[for (i of [1,4,2,3,-8]) if (i < 3) i]; -// 等价于 -[1,4,2,3,-8].filter(function(i) { return i < 3 }); -``` - -上面代码说明,模拟`map`功能只要单纯的`for...of`循环就行了,模拟`filter`功能除了`for...of`循环,还必须加上`if`语句。 - -在一个数组推导中,还可以使用多个`for...of`结构,构成多重循环。 - -```javascript -var a1 = ['x1', 'y1']; -var a2 = ['x2', 'y2']; -var a3 = ['x3', 'y3']; - -[for (s of a1) for (w of a2) for (r of a3) console.log(s + w + r)]; -// x1x2x3 -// x1x2y3 -// x1y2x3 -// x1y2y3 -// y1x2x3 -// y1x2y3 -// y1y2x3 -// y1y2y3 -``` - -上面代码在一个数组推导之中,使用了三个`for...of`结构。 - -需要注意的是,数组推导的方括号构成了一个单独的作用域,在这个方括号中声明的变量类似于使用`let`语句声明的变量。 - -由于字符串可以视为数组,因此字符串也可以直接用于数组推导。 - -```javascript -[for (c of 'abcde') if (/[aeiou]/.test(c)) c].join('') // 'ae' - -[for (c of 'abcde') c+'0'].join('') // 'a0b0c0d0e0' -``` - -上面代码使用了数组推导,对字符串进行处理。 - -数组推导需要注意的地方是,新数组会立即在内存中生成。这时,如果原数组是一个很大的数组,将会非常耗费内存。 -