해결된 질문
작성
·
89
0
안녕하세요. 질문 있습니다.
수업에 아래와 같은 코드를 사용했습니다.
type Post = {
title: string;
content: string;
author: {
id: number;
name: string;
age: number;
};
};
type Author = Post['author']
제가 궁금한 것은 처음부터 Author 타입을 분리해서 선언하고 그 타입을 Post에서 가져다 쓰면 안되나요?
타사 라이브러리에 타입이 잘못 선언돼 있다면 유용할 것 같긴 한데 그 외에도 어떤 사용 방법이 있을지 궁금합니다.
감사합니다. 새해 복 많이 받으세요!
답변 2
0
안녕하세요 이정환입니다.
네 맞습니다. Author 타입을 분리 해 사용 가능할 경우 그렇게 하는게 편하긴 하겠죠
다만 본 강의는 타입스크립트의 여러 기능을 살펴보는 목적으로 진행되기 때문에, 코드의 효율성 보다는 기능 활용에 더 초점을 맞추어 진행됨을 알려드립니다 😃 이런 방식으로도 활용할 수 있다 정도로 이해하시면 되겠습니다.
0
안녕하세요, 인프런 AI 인턴입니다. Raehan Jeong님.
질문 주셔서 감사합니다! TypeScript에서 타입을 어떻게 분리하고 재사용할 수 있는지에 대해 질문 주셨군요.
주어진 코드에서 type Author = Post['author']
는 인덱스드 엑세스 타입(indexed access type)을 사용하여 기존 타입인 Post
의 속성 author
의 타입을 Author
로 추출하고 있습니다. 이 방식은 여러 용도로 유용할 수 있습니다:
타입 안정성: 이미 정의된 타입의 하위 속성에 대한 타입을 직접 가져오기 때문에 타입의 일관성을 유지할 수 있습니다. 만약 Post
의 author
타입이 달라지면 Author
도 자동으로 반영됩니다.
유지보수 용이: 코드를 유지보수할 때 수정해야 할 부분이 줄어듭니다. 만약 Post
내의 author
구조가 변경된다면, 중복된 타입 정의를 수정하지 않아도 됩니다.
라이브러리 활용: 외부 라이브러리에서 잘못된 타입 정의나 불완전한 타입 정의가 있을 때, 인덱스드 엑세스 타입을 활용하여 필요한 부분만 추출하거나 수정할 수 있습니다.
물론 Author
타입을 처음부터 독립적으로 선언하는 것도 가능합니다. 이렇게 하면 Post
타입과 독립적으로 Author
를 수정할 수 있지만, 두 타입의 동기화를 직접 관리해야 합니다.
이에 관련된 유사한 질문과 답변이 이미 게시판에 존재하여 아래 링크를 참고하면 더 도움이 될 것 같습니다:
지금까지의 설명이 도움이 되셨기를 바라며, 새로운 해에도 좋은 학습되시기 바랍니다!
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.