使用扩展语法和带有typescript的新Set()

Egg*_*ggy 68 javascript typescript ecmascript-6 spread-syntax

我使用以下代码来获取唯一的数字:

let uniques = [ ...new Set([1, 2, 3, 1, 1]) ]; // [1, 2, 3]
Run Code Online (Sandbox Code Playgroud)

但是,typescript报告跟随错误:类型"Set"不是数组类型. 我不是打字稿忍者,有人能告诉我这里有什么问题吗?

Ret*_*sam 68

更新:使用Typescript 2.3,您现在可以添加"downlevelIteration": true到您的tsconfig,这将在定位ES5时有效.

缺点downlevelIteration是TS在转换时必须注入相当多的样板.问题的单行转换为21行添加的样板:(截至稿例2.6.1)

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);
Run Code Online (Sandbox Code Playgroud)

每个使用下层迭代的文件将为此样板注入一次,并且可以使用"importHelpers"tsconfig中的选项减少此样板.(请参阅有关下层迭代的博客文章importHelpers)

或者,如果ES5支持对您无关紧要,您可以始终只是首先定位"es6",在这种情况下,原始代码无需"downlevelIteration"标记即可运行.


原始答案:

这似乎是一个打字稿ES6翻译的怪癖.该...经营者应在任何有一个iterator属性(由工作访问的obj[Symbol.iterator]),并设置有属性.

要解决此问题,您可以使用Array.from首先将集合转换为数组:...Array.from(new Set([1, 2, 3, 1, 1])).

  • @Restam 很好的解决方案,使用 `Array.from`。大多数其他人似乎只是放弃了这一点。感谢您提供真正的解决方案! (3认同)

Nat*_*tch 46

您还可以使用Array.from方法将Set转换为Array

let uniques = Array.from(new Set([1, 2, 3, 1, 1])) ;
console.log(uniques);
Run Code Online (Sandbox Code Playgroud)

  • 关键是如果你使用`Array.from()`,你就不再需要展开操作符了。它只会增加开销。`let uniques = Array.from(new Set([1, 2, 3, 1, 1]));` (3认同)
  • @RobbyCornelissen 上述代码的全部原因是创建一个具有原始数组的唯一值的数组 (2认同)

bas*_*rat 29

这是一个缺失的功能.TypeScript目前仅支持Arrays上的迭代.


Naj*_*thi 18

在 JavaScript 中:

[ ...new Set([1, 2, 3, 1, 1]) ]
Run Code Online (Sandbox Code Playgroud)

在打字稿中:

Array.from(new Set([1, 2, 3, 1, 1]))
Run Code Online (Sandbox Code Playgroud)

在反应状态(setState)中:

setCart(Array.from(new Set([...cart, {title: 'Sample', price: 20}])));
Run Code Online (Sandbox Code Playgroud)


Shi*_*Jha 12

现在,您可以Set在 Typescript 设置中使用(无需目标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'. */
    
  },
  ...
}
Run Code Online (Sandbox Code Playgroud)


phi*_*294 6

您需要"target": "es6",在tsconfig中进行设置。