typescript와 함께 스프레드 구문 및 new Set () 사용


91

고유 번호를 얻기 위해 다음 코드를 사용하고 있습니다.

let uniques = [ ...new Set([1, 2, 3, 1, 1]) ]; // [1, 2, 3]

그러나 typescript는 다음 오류를보고합니다. 'Set'유형은 배열 유형이 아닙니다. 나는 타이프 스크립트 닌자가 아닙니다. 누군가 여기서 무엇이 잘못되었는지 말해 줄 수 있습니까?


4
사용하는 버전이 ES2015를 지원한다고 주장하는 경우 Typescript 버그라고 생각합니다.
Pointy

1
@Pointy 죄송합니다. 1.6.2 인 tsc 버전을 포함해야합니다.
Eggy

답변:


39

이것은 누락 된 기능입니다. TypeScript는 현재 배열에서 이터 러블 만 지원합니다.


설명해 주셔서 감사합니다. .filter () 또는 다른 것을 사용하여 작업을 완료합니다. 이 특정 오류에 대해 github에서 몇 가지 문제를 발견했습니다. 향후 릴리스에서 이에 대해 주시하겠습니다.
Eggy

95

업데이트 : Typescript 2.3을 사용하면 이제 "downlevelIteration": truetsconfig에 추가 할 수 있으며 ES5를 대상으로하는 동안 작동합니다.

단점은 downlevelIterationTS가 트랜스 파일 할 때 꽤 많은 상용구를 삽입해야한다는 것입니다. 질문의 한 줄은 21 줄의 추가 된 상용구로 변환됩니다. (Typescript 2.6.1 기준)

이 상용구는 다운 레벨 반복을 사용하는 파일 당 한 번씩 주입 "importHelpers"되며 tsconfig를 통해 옵션을 사용하여이 상용구를 줄일 수 있습니다 . ( 하위 수준 반복 및 ) 에 대한 이 블로그 게시물 을 참조하십시오.importHelpers

또는 ES5 지원이 중요하지 않은 경우 항상 처음에 "es6"을 대상으로 지정할 수 있습니다.이 경우 원래 코드가 "downlevelIteration"플래그없이 작동합니다.


원래 답변 :

이것은 typescript ES6 transpilation 특이한 것 같습니다. ...운영자는 반복자 속성 (액세스를 가지고 어떤 작업을해야한다 obj[Symbol.iterator])과 설정은 그 속성이 있습니다.

이 문제를 해결하려면 Array.from먼저 세트를 배열로 변환하는 데 사용할 수 있습니다 ...Array.from(new Set([1, 2, 3, 1, 1]))..


@Restam : tsconfig.json의 "target": "es5"인 경우 typescript가 IE의 Array.from에 대한 polyfill을 제공합니까?
jackOfAll

1
@jackOfAll 아니요, Typescript는 프로토 타입을 폴리 필링하지 않습니다. "target": "es5"를 설정하면 폴리 필이 필요한 메소드를 사용하려고하면 컴파일러 오류가 발생합니다.
Retsam

1
@Restam 훌륭한 솔루션 Array.from. 대부분의 다른 사람들은 이것을 포기하는 것 같습니다. 실제 솔루션에 감사드립니다!
rayepps

버그가 아니며 es5대상에 대해 지원하지 않습니다 ( github.com/Microsoft/TypeScript/issues/4031 참조 ). tsconfig 의 목록에 이상 ( , )이있는 Array.from경우 작동합니다 . es2015es2017esnextlib
Simon Hänisch

1
@ SimonHänisch 링크 주셔서 감사합니다. 저는 제 답변을 업데이트했습니다. 더 이상 "버그"라고 부르지 않고 "트랜스 필 레이션 기이함"이라고 부르는데 아마도 더 정확한 용어 일 것입니다. 또한 해당 링크에서 하위 수준 반복 옵션에 대한 정보를 추가하여 원래 문제도 해결했습니다.
Retsam 2017

67

Array.from 메서드를 사용하여 Set를 Array로 변환 할 수도 있습니다.

let uniques = Array.from(new Set([1, 2, 3, 1, 1])) ;
console.log(uniques);


새 어레이에서 다시 캡처하기 위해 어레이를 확산시키는 이유는 무엇입니까?
Robby Cornelissen

1
tsconfig에서 "es6"을 대상으로 지정할 수없는 경우 그리고 확산 연산자와 함께 설정을 사용해야합니다. 어떻게 하시겠습니까?
Nate Getch

요점은를 사용 Array.from()하면 더 이상 스프레드 연산자가 필요하지 않다는 것입니다. 오버 헤드를 추가 할뿐입니다. let uniques = Array.from(new Set([1, 2, 3, 1, 1]));
Robby Cornelissen

8

"target": "es6",tsconfig에서 설정해야합니다 .


0

작동하려면 tsconfig.json의 compilerOptions에서 "target": "ES6"(또는 그 이상) 또는 "downlevelIteration": true가 필요합니다. 이것은 내 문제를 해결하고 잘 작동하며 당신에게도 도움이되기를 바랍니다.


-1

자바 스크립트에서 :

[ ...new Set([1, 2, 3, 1, 1]) ]

Typescript에서 :

Array.from(new Set([1, 2, 3, 1, 1]))

반응 상태 (setState)에서 :

setCart(Array.from(new Set([...cart, {title: 'Sample', price: 20}])));
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.