상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - 타입스크립트에서 Readonly 타입은 어떻게 사용하나요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
타입스크립트에서 `Readonly` 타입은 객체의 프로퍼티를 읽기 전용으로 만들어, 해당 프로퍼티의 값을 변경할 수 없도록 하는 데 사용됩니다. 이는 불변성을 유지하고, 코드의 안정성을 높이는 데 중요한 역할을 합니다. `Readonly` 타입을 사용하면 객체의 상태를 보호하고, 의도치 않은 변경으로부터 코드를 안전하게 지킬 수 있습니다. 기본 사용법 `Readonly`는 타입스크립트의 내장 유틸리티 타입 중 하나로, 객체 타입을 인자로 받아 모든 프로퍼티를 읽기 전용으로 변환합니다. 기본적인 사용법은 다음과 같습니다: ```typescript interface User { name: string; age: number; } const user: Readonly<User> = { name: "Alice", age: 30 }; // 아래와 같은 변경 시도는 오류를 발생시킵니다. user.name = "Bob"; // 오류: Cannot assign to 'name' because it is a read-only property. ``` 위의 예제에서 `Readonly<User>`를 사용하여 `user` 객체의 모든 프로퍼티를 읽기 전용으로 만들었습니다. 이제 `name`과 `age` 프로퍼티는 더 이상 수정할 수 없습니다. ReadonlyArray 타입스크립트는 배열에 대해서도 `ReadonlyArray`라는 타입을 제공합니다. 이 타입은 배열의 요소를 읽기 전용으로 만들어, 배열의 내용을 변경할 수 없도록 합니다. ```typescript const numbers: ReadonlyArray<number> = [1, 2, 3]; // 아래와 같은 변경 시도는 오류를 발생시킵니다. numbers.push(4); // 오류: Property 'push' does not exist on type 'readonly number[]'. ``` 위의 예제에서 `numbers`는 `ReadonlyArray<number>` 타입으로 선언되어, 배열의 요소를 추가하거나 삭제하는 등의 변경을 할 수 없습니다. 중첩된 Readonly `Readonly`는 중첩된 객체에도 적용할 수 있습니다. 다음 예제를 살펴보겠습니다: ```typescript interface Address { street: string; city: string; } interface User { name: string; address: Address; } const user: Readonly<User> = { name: "Alice", address: { street: "123 Main St", city: "Wonderland" } }; // 아래와 같은 변경 시도는 오류를 발생시킵니다. user.address.city = "New Wonderland"; // 오류: Cannot assign to 'city' because it is a read-only property. ``` 위의 예제에서 `User` 객체의 `address` 프로퍼티 또한 `Readonly`로 선언되어, 내부의 `city` 프로퍼티도 읽기 전용이 됩니다. Readonly와 타입 추론 타입스크립트는 `Readonly`를 사용하여 타입 추론을 할 수 있습니다. 예를 들어, 함수의 매개변수로 `Readonly` 타입을 사용할 수 있습니다: ```typescript function printUser(user: Readonly<User>) { console.log(user.name); console.log(user.age); } // user 객체를 전달할 수 있지만, 수정할 수는 없습니다. printUser(user); ``` 이렇게 하면, `printUser` 함수 내에서 `user` 객체를 수정할 수 없도록 보장할 수 있습니다. 결론 타입스크립트의 `Readonly` 타입은 객체의 불변성을 유지하고, 코드의 안정성을 높이는 데 유용한 도구입니다. 객체의 프로퍼티를 읽기 전용으로 만들고, 배열의 요소를 수정할 수 없도록 하는 기능을 제공하여, 의도치 않은 변경으로부터 코드를 보호합니다. 이러한 특성 덕분에, 대규모 애플리케이션에서 상태 관리와 데이터 흐름을 보다 안전하게 처리할 수 있습니다. `Readonly`와 `ReadonlyArray`를 적절히 활용하면, 코드의 가독성과 유지보수성을 높일 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기