我正在使用以下代码获取唯一数字:
let uniques = [ ...new Set([1, 2, 3, 1, 1]) ]; // [1, 2, 3]
然而,TypeScript 报告了如下错误:Type 'Set' is not an array type. 我不是 TypeScript 的专家,有没有人能告诉我这里出了什么问题?
我正在使用以下代码获取唯一数字:
let uniques = [ ...new Set([1, 2, 3, 1, 1]) ]; // [1, 2, 3]
然而,TypeScript 报告了如下错误:Type 'Set' is not an array type. 我不是 TypeScript 的专家,有没有人能告诉我这里出了什么问题?
"downlevelIteration": true
添加到您的tsconfig中,并且在针对ES5时它将起作用。 downlevelIteration
的缺点是,在进行转译时,TS将不得不注入相当多的样板文件。截至Typescript 2.6.1,问题的单行转译带有21行添加的样板文件。
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
var __spread = (this && this.__spread) || function () {
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
return ar;
};
var uniques = __spread(new Set([1, 2, 3, 1, 1]));
console.log(uniques);
这个样板将在使用下级迭代的每个文件中注入一次,并且可以通过tsconfig选项中的"importHelpers"
来减少这个样板(参见this blogpost关于下级迭代和importHelpers
的说明)。
另外,如果您不需要ES5支持,您可以直接以"es6"为目标,这种情况下原始代码不需要"downlevelIteration"标志也可以工作。
原始答案:
这似乎是TypeScript ES6转换的一个怪癖。 ...
操作符应该适用于具有迭代器属性的任何内容(通过 obj [Symbol.iterator]
访问),并且集合具有该属性。
要解决此问题,您可以使用 Array.from
将集合先转换为数组:...Array.from(new Set([1, 2, 3, 1, 1]))
。
Array.from
解决方案很棒。大多数人似乎都放弃了。感谢提供真正的解决方案! - rayeppses5
目标(请参阅 https://github.com/Microsoft/TypeScript/issues/4031)。如果您在 tsconfig 的 lib 列表中具有 es2015
或更高版本(es2017
,esnext
),Array.from
应该可以正常工作。 - Simon Hänischlet uniques = Array.from(new Set([1, 2, 3, 1, 1])) ;
console.log(uniques);
Array.from()
,就不再需要使用扩展运算符。扩展运算符只会增加额外负担。例如:let uniques = Array.from(new Set([1, 2, 3, 1, 1]));
- Robby Cornelissen这是一个缺失的功能。目前,TypeScript仅支持数组上的可迭代对象。
在Javascript中:
[ ...new Set([1, 2, 3, 1, 1]) ]
在 TypeScript 中:Array.from(new Set([1, 2, 3, 1, 1]))
在 React 中的 State(状态)(setState)中:
setCart(Array.from(new Set([...cart, {title: 'Sample', price: 20}])));
您需要在tsconfig中设置"target": "es6"
。
现在,您可以在TypeScript设置中使用Set
(无需针对es6
目标):
在您的tsconfig.json
中,添加此行:
{
"compilerOptions": {
/* Visit https://aka.ms/tsconfig.json to read more about this file */
"downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
},
...
}