[Nextjs + Typescript] velog 클론코딩/[ Nextjs + Typescript ] 나를 위한 기록

9. ''의 형식의 인수는 ''형식의 매개 변수에 할당될 수 없습니다.

tnqlscho 95 2023. 2. 15. 23:55

메인페이지의 카드 게시글의 제목으로 reudx toolkit에 저장되어있는 해당 상세페이지 글을 걸러서 보여주려고 했었다.

하지만 뭘 가져오면 어김없이 뜨는 빨간줄..ㅠ

읽어보니 또 type 문제였던거 같다...

 

구글링을 통해서 타입 단언 as type로 해결했다.

router.query에서 가져온 title을 typescript가 인지하는 타입이 있다고 하더라도 내가 받아오는 title값은 배열도

undefined도 아닌 string으로 생각하게끔 as string을 넣어줬다.

 

그런데 데이터가 복잡하거나 내가 원하는 데이터의 타입에 대해 확실하지 않을 경우에는 타입단언을 남용하면 안될것 같다..

 

타입 선언은 기존에 설정되어있는 interpace에 맞게 들어가는지 검사를 하는데

내가 쓴 타입 단언은 내가 router.query에서 넘어오는 title은 string이라고 강제로 지정을 했기때문에

type 검사때 오류가 아니니 무시하라고 한것이기 때문.

 

 

* 출처

https://baek.dev/til/typescript/effective-typescript/ch02/item9