HTML 클래스 바인딩
객체 바인딩
클래스를 동적으로 바인딩 하기위해서는 :class(v-bind:class)를 사용할 수 있습니다.
<div
class="text"
:class="{ active: isActive, 'text-danger': hasError }"
></div
위 예시처럼 v-bind:class 디렉티브는 일반 class속성과 공존할 수 있습니다. 그리고 객체를 반환하는 computed에 바인딩할 수도 있습니다.
<div class="text" :class="classObject"></div>
const classObject = computed(() => ({
active: isActive.value && !hasError.value,
'text-danger': !isActive.value && hasError.value,
}));
배열에 바인딩
배열에 :class를 바인딩하여 클래스 목록을 적용할 수 있습니다.
const activeClass = ref('active')
const errorClass = ref('text-danger')
<div :class="[activeClass, errorClass]"></div>
인라인 스타일 바인딩
HTML style 속성에 객체값을 바인딩할 수 있습니다.
const activeColor = ref('red')
const fontSize = ref(30)
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
템플릿이 더 깔끔해지도록 스타일 객체에 직접 바인딩하는 것이 좋습니다.
const styleObject = reactive({
color: 'red',
fontSize: '13px'
})
<div :style="styleObject"></div>
배열에 바인딩
:style 또한 여러 개의 객체를 배열에 바인딩할 수 있습니다.
<div :style="[commonStyleObject, divStyleObject]"></div>
'FrontEnd > Vue' 카테고리의 다른 글
[Vue3] 리스트 렌더링 (0) | 2023.04.17 |
---|---|
[Vue3] 조건부 렌더링 (0) | 2023.04.17 |
[Vue3] Computed (0) | 2023.04.17 |
[Vue3] 반응형 데이터 기초 (0) | 2023.04.17 |
[Vue3] Setup hook (0) | 2023.04.02 |