我尝试在map
中使用new Array()
构造函数,以便创建一个创建元素列表的单行代码。如下所示:
let arr = new Array(12).map( (el, i) => {
console.log('This is never called');
return i + 1;
});
阅读docs,这种行为是有意义的。
文档基本上说,即使在数组中声明了未定义的值,也会执行map的回调,但不会像之前的代码那样创建空数组。
因此,这应该是可行的:
var arr = new Array(12);
for(let i = 0; i < arr.length ; i++){
arr[i] = undefined;
}
let list = arr.map( (e, i) => {
console.log(i + 1);
return i + 1;
});
所以,我们也可以这样做:
let newArray = (length) => {
let myArray = new Array(length);
for(let i = 0; i < length; i++) myArray[i] = undefined;
return myArray;
};
console.log( newArray(12).map( (el, i) => i + 1 ) );
所以我的问题是。有没有更好/更好的使用map函数的方法呢?
提前感谢!
发布于 2016-05-27 23:49:10
您可以使用Array#from
创建具有传递长度的数组。
Array.from({length: 12}, (e, i) => i + 1);
发布于 2018-05-31 17:54:22
如果我没记错的话,你明确地说过你想要一个新的数组构造函数的答案。
下面是如何做到这一点的。一句话,漂亮的ES6:
let me = [...new Array(5)].map((x,i)=>i)
// [0,1,2,3,4]
解释:
new Array(5)
生成以下内容:[ , , , , ]
[...new Array(5)]
是Array.from(new Array(5))
的缩写,并生成以下内容:[ undefined, undefined, undefined, undefined, undefined ]
,即undefined
对象的数组。是的,undefined
是一个值(一个原始值:)。PS:您甚至可以跳过new
关键字并执行以下操作:
[...Array(5)].map((x,i)=>i)
发布于 2016-05-27 23:49:21
the spec的Section 22.1.3.15正在使用NOTE 1
的最后一行代码
callbackfn仅对数组中实际存在的元素调用;不对数组中缺少的元素调用。
filter
、forEach
和其他函数式方法都有这种行为。
您正在调用的数组构造函数(来自section 22.1.1.2的Array(len)
)将设置数组的长度,但不会初始化元素。我不确定规范在哪里定义了缺失的元素,但是由new Array(len)
生成的数组应该符合这一点,因此map
不会接触到任何元素。
https://stackoverflow.com/questions/37487602
复制相似问题