일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- HTML
- 블록체인
- 쿠버네티스
- AWS
- 컴퓨터공학
- VUE
- kubernetes
- JavaScript
- 리액트
- 파이썬
- 자바스크립트
- es6
- k8s
- BFS
- docker
- 솔리디티
- 클라우드
- CSS
- 백엔드
- 타입스크립트
- 프론트엔드
- TypeScript
- 이슈
- 이더리움
- 웹
- 가상화
- react
- 알고리즘
- next.js
- 백준
- Today
- Total
즐겁게, 코드
v-show와 v-if 지시자의 차이 본문
조건부 렌더링
뷰(Vue.js)에서는 특정 조건을 만족할 때만 컴포넌트나 블록을 렌더링하는 조건부 렌더링 을 위해 v-if
와 v-show
라는 두 종류의 지시자(directive)를 사용합니다.
<!-- 두 블록은 isVisible이 참일 때만 화면에 나타납니다. -->
<div id="root">
<div v-show="isVisible">v-show를 사용한 블록</div>
<div v-if="isVisible">v-if를 사용한 블록</div>
</div>
그런데, 왜 뷰는 동일한 역할을 수행하는 지시자를 둘이나 구현해둔 걸까요?
v-if 지시자
사실 두 지시자는 엄밀히 다른 방식으로 조건부 렌더링을 구현합니다.
먼저 v-if
지시자를 볼까요?
<!-- index.html 코드 부분 -->
<div id="root">
<div v-if="isVisible">v-if를 사용한 블록</div>
</div>
[렌더링 결과 : isVisible이 true일 때]
<div id="root" data-v-app="">
<div>v-if를 사용한 블록</div>
</div>
[렌더링 결과 : isVisible이 false일 때]
<div id="root" data-v-app="">
<!--v-if-->
</div>
v-if
지시자는 조건이 참일 때는 블록을 새로 생성해 DOM 트리에 추가하고, 조건이 거짓으로 변하면 해당 블록을 DOM 트리에서 완전히 삭제합니다.
또한 초기 렌더링 시, 조건이 거짓이라면 처음부터 렌더링을 수행하지 않는다는 특징이 있습니다.
v-show 지시자
v-if
가 조건부 렌더링 과정에서 DOM 트리를 직접 조작했다면 v-show
는 조건이 참일 때는 정상적으로 블록을 렌더링하고, 조건이 거짓일 때는 해당 블록에 display: none
인라인 스타일을 적용합니다.
<!-- index.html 코드 부분 -->
<div id="root">
<div v-show="isVisible">v-show를 사용한 블록</div>
</div>
[렌더링 결과 : isVisible이 true일 때]
<div id="root" data-v-app="">
<div>v-show를 사용한 블록</div>
</div>
[렌더링 결과 : isVisible이 false일 때]
<div id="root" data-v-app="">
<div style="display: none;">v-show를 사용한 블록</div>
</div>
또한 v-if
가 초기 렌더링 시 조건이 거짓이라면 처음부터 렌더링을 수행하지 않는 것과는 달리, v-show
는 일단 렌더링을 수행하고 조건을 평가해 display:none
스타일을 부여할지를 결정합니다.
정리
둘의 차이는 얼핏 보면 단순히 적용 방식에만 있는 것 같지만, 상황에 따라 이 둘은 성능과도 밀접한 관련이 있습니다.
v-if
는 해당 블록(또는 컴포넌트)을 DOM 트리에서 제어하다 보니 전환 비용이 커 조건이 자주 변하는 경우에는 적합하지 않지만, 초기 렌더링 시 조건이 거짓이라면 렌더링을 아예 생략한다는 점으로 인해 초기 단계에서 조건이 결정되는 상황에 유리합니다.
대신 토글 메뉴처럼 런타임 단계에서 조건이 자주 변경되는 요소라면, 이런 경우에는 v-show
를 사용하는 것이 적합합니다.
'🎨 프론트엔드 > Vue.js' 카테고리의 다른 글
vee-validate에 타입스크립트 적용하기 (@vee-validate/yup) (0) | 2024.12.19 |
---|---|
[Vue] inject-provide 패턴 조금 더 잘 써보기 (0) | 2024.11.19 |
Vue 3에서 페이지 전환 애니메이션 추가하기 (0) | 2023.12.24 |
Vuex의 namespaced module 활용하기 (0) | 2022.04.04 |
Vue 컴포넌트에서 name 속성을 명시하는 이유 (0) | 2021.05.24 |