computed 의 set 함수를 통해 const 변수에 값을 담는 부분
53
7 asked
안녕하세요?
이번에 16강 Computed 강좌를 듣다가 궁금한 게 있어서 질문을 남깁니다.
const fullName = computed({
get...
set...
});
이렇게 할당을 하는데 const는 상수로 알고 있는데 저렇게 선언하고 fullName에 다른 값을 할당하는게 가능한가요?
fullName = '새로운 값' 이렇게 하면 스크립트 에러가 나는데 fullName.value를 붙여서 할당해서 괜찮은 것 같긴 한데...좀 헤깔리네요...
Answer 2
0
안녕하세요! 🙂
핵심은 const가 보호하는 건 "변수 자체의 재할당"이지, "객체 내부 속성의 변경"이 아니라는 점이에요.
computed()가 반환하는 건 하나의 ref 객체예요. 쉽게 말하면 이런 구조입니다:
// computed가 반환하는 건 대략 이런 모양의 객체
const fullName = { value: '짐코딩' }
그래서 fullName = '새로운 값'은 변수 자체를 다른 값으로 바꾸려는 거라 const 위반으로 에러가 나고, fullName.value = '새로운 값'은 객체 내부의 .value 속성을 바꾸는 거라 전혀 문제가 없는 거예요.
JavaScript 배열에서도 같은 원리가 적용돼요:
const arr = [1, 2, 3]
arr.push(4) // ✅ 내부 변경이라 OK
arr = [5, 6, 7] // ❌ 재할당이라 에러
그러니까 fullName.value = '...'으로 할당하면 computed의 set 함수가 호출되는 구조이고, const와는 충돌이 없습니다.
0
안녕하세요, 인프런 AI 인턴입니다. diaman75님.
computed 속성에 대해 궁금하신 점 잘 이해했습니다. Vue 3에서 computed는 getter와 setter를 제공할 수 있는 특별한 종류의 반응형 객체입니다. 이를 통해 상태의 변화를 감지하고 반응형 데이터와 상관없이 적절히 업데이트할 수 있습니다.
질문하신 부분을 정리하자면:
const fullName = computed({...}):- 이는
computed함수를 사용하여fullName이라는 반응형 속성을 정의하는 것입니다.
const키워드는fullName이라는 변수 그 자체가 다른 값으로 재할당될 수 없음을 뜻합니다. 하지만 반응형 데이터를 담고 있는 객체 내부의 상태를 변화시키는 것은 가능합니다.
- 이는
fullName.value = "새로운 값":fullName은 자바스크립트의Ref객체를 반환합니다. 따라서.value프로퍼티를 통해 실제 값을 읽거나 쓸 수 있습니다.
- 이는
computed속성의 setter가 특정 동작을 해서 반응형 상태를 업데이트하도록 설계됩니다.
이처럼 const로 선언된 변수가 지니고 있는 객체의 내부 상태는 바꿀 수 있습니다. 함수나 객체의 내부 상태는 객체의 프로퍼티로 관리되기 때문에, 외부에서 .value나 다른 프로퍼티를 통해 접근 및 수정 가능합니다.
관련하여 추가로 참고하실 수 있는 질문이 있습니다:
- reactive와 computed 차이 질문
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
npm init vue@3.1.9
0
41
2
크롭 웹스토어 vue devtools 설치 관련
0
42
1
snippets 작성하는 부분 설명이 있었나요?
0
49
2
소스 공유 어디서 해야하는지 궁금합니다
0
61
2
component 등록과 사용
0
58
2
강의교안
0
56
2
eslint 룰 관련 질문이 있습니다.
0
64
2
npm init -y 명령어 실행에 관한 질문
0
154
2
volar 가 마켓플레이스에 검색되지 않아 vue(official)을 설치했습니다.
0
168
2
깊은 감시자 질문
0
88
2
정리된 내용
0
155
2
화면이 왜 이렇게 뜨는걸까요?
0
186
2
왜 다르게 뜰까요..?ㅠㅠ
0
155
2
npm init vue , npm create vue@latest 명령 오류
0
294
2
강의를 듣다보니 궁금한 점 질문드립니다.
0
141
2
watch강의 질문
0
153
1
강의 듣다가 질문드립니다.
0
119
1
이벤트 처리 부분 강의 실습
0
141
2
v-pre는 설명이 없나요?
0
153
2
AppCard.vue 만들다 말고 오류가 갑자기 엄청 뜹니다
0
146
1
개발자도구 Vue 탭 관련 문의
0
240
2
강의를 인텔리제이로 수업따라가도 되져?
0
178
2
API 사용시 자동으로 import하는 기능은 어떤것을 설치해야 하나요?
3
279
2
이벤트 수식어 event 전달인자 관련 질문
0
138
1

