Обновление : с помощью Typescript 2.3 теперь вы можете добавить "downlevelIteration": true
в свой tsconfig, и это будет работать при ориентации на ES5.
Недостатком downlevelIteration
является то , что TS придется вводить совсем немного шаблонный , когда transpiling. Единственная строка из вопроса транслируется с 21 строкой добавленного шаблона: (с Typecript 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);
Этот шаблон будет внедрен один раз в файл, который использует итерацию нижнего уровня, и этот шаблон можно уменьшить, используя "importHelpers"
параметр через tsconfig. (См. Это сообщение в блоге об итерации нижнего уровня и importHelpers
)
В качестве альтернативы, если поддержка ES5 для вас не имеет значения, вы всегда можете просто настроить таргетинг на «es6», и в этом случае исходный код будет работать без флага «downlevelIteration».
Оригинальный ответ:
Это похоже на причуду машинописной транспиляции ES6. ...
Оператор должен работать на все , что имеет свойство итератора, (к которым обращается obj[Symbol.iterator]
) и наборы имеют это свойство.
Чтобы обойти эту проблему , вы можете использовать , Array.from
чтобы преобразовать набор в массив первым: ...Array.from(new Set([1, 2, 3, 1, 1]))
.