![](/img/trans.png)
[英]How to match a number with the numbers in array in vanilla JavaScript?
[英]Vanilla Javascript unique numbers in array with reduce and find
我正在尝试使用reduce和find helper来编写一个数组函数,该函数返回一个唯一数字数组。
var numbers = [1, 1, 2, 3, 4, 4]; // function should return [1, 2, 3, 4] function unique(array) { array.reduce((uniqueArray, number) => { if (uniqueArray.indexOf(find(array.number))) { uniqueArray.push(array.number); } return uniqueArray; }, []); } console.log(unique(numbers)); // undefined // undefined
运行此代码时,我得到了
未定义
两次在浏览器Javascript控制台中。
以前的答案解释了错误的原因。 所以我只是添加了一个使用Array#filter
方法的替代方法。
var numbers = [1, 1, 2, 3, 4, 4]; // function should return [1, 2, 3, 4] function unique(array) { return array.filter(function(v, i, arr) { // compare index with first element index return i == arr.indexOf(v); }) } console.log(unique(numbers));
具有ES6箭头功能。
var numbers = [1, 1, 2, 3, 4, 4]; // function should return [1, 2, 3, 4] function unique(array) { return array.filter((v, i, arr) => i == arr.indexOf(v)) } console.log(unique(numbers));
更新:使用引用对象而不是检查索引。
var numbers = [1, 1, 2, 3, 4, 4], ref = {}; function unique(array) { return array.filter(function(v) { if (!(v in ref)) { ref[v] = true; return true; } return false; }) } console.log(unique(numbers));
您需要一份退货声明。
return array.reduce((uniqueArray // ...
// ^^^
还有一些更好的Array.indexOf
查找方法
function unique(array) { return array.reduce((uniqueArray, number) => { if (uniqueArray.indexOf(number) === -1) { uniqueArray.push(number); } return uniqueArray; }, []); } var numbers = [1, 1, 2, 3, 4, 4]; console.log(unique(numbers));
现在使用Set
和spread语法...
来收集新数组中的项目。
function unique(array) { return [... new Set(array)]; } var numbers = [1, 1, 2, 3, 4, 4]; console.log(unique(numbers));
你几乎没有错误。 首先,您需要从函数返回值,并检查元素是否已经在uniqueArray
您可以使用indexOf()
== -1
。
var numbers = [1, 1, 2, 3, 4, 4]; function unique(array) { return array.reduce((uniqueArray, number) => { if (uniqueArray.indexOf(number) == -1) uniqueArray.push(number) return uniqueArray; }, []); } console.log(unique(numbers));
使用ES6 / 7,您可以使用includes()
和箭头功能。
var numbers = [1, 1, 2, 3, 4, 4]; function unique(arr) { return arr.reduce((r, n) => (!r.includes(n) ? r.push(n) : 1) && r , []); } console.log(unique(numbers));
您始终可以使用Array.includes
。
function SillyFunctionName(array) {
"use strict";
var uniqueArray = [];
for (var i = 0; i < array.length; i++) {
if (uniqueArray.includes(array[i])) {
break;
} else {
uniqueArray.push(array[i]);
}
}
return uniqueArray;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.