: 현재 컴포넌트의 엘리먼트들에만 CSS를 적용
<style>
/* 전역 CSS */
</style>
<style scoped>
/* 현재 컴포넌트에만 적용 */
</style>
-> 특정 컴포넌트의 스타일이 다른 컴포넌트에 영향을 주는것을 방지
=> scoped CSS를 사용하면 돔 속성에 랜덤한 속성 이름 생성
(ex: data-v-f3f3fdk)
=> 클래스 이름이 해당 속성 이름과 함께 명시된다
(ex: .example -> .example[data-v-f3f3fdk])
: 하위 컴포넌트 스타일 적용 안됨
-> 하위 컴포넌트의 scoped 속성 이름은 부모와 다르거나 속성 이름이 없다(scoped 설정을 하지 않는 경우)
calender.vue 컴포넌트에서 vuetify v-date-picker 사용
-> 위와 같이 공휴일/일요일에 색을 빨간색으로 변경 희망
-> date-picker에서 각각의 날짜를 나타내는 부분에 document 객체를 사용해 .holiday-color 클래스를 삽입
-> css를 통해 색을 빨간색으로 변경
<style scoped>
.v-date-picker .v-date-picker-table .v-btn .holiday-color{
color: red;
}
</style>
-> 스타일이 적용되지 않는다
(scoped 속성 이름이 붙기 때문)
: Deep Selectors 사용 ( >>> )
<style scoped>
.v-date-picker >>> .v-date-picker-table .v-btn:not(.v-btn--disabled) .holiday-color{
color: red;
}
/* 아래와 같이 변환된다 */
.v-date-picker[data-v-f3f3eg9] .v-date-picker-table .v-btn:not(.v-btn--disabled) .holiday-color{
color: red;
}
</style>
-> .v-date-picker-table 클래스를 가진 돔의 scoped 속성명에 상관없이 동작한다.
-> >>> 대신 /deep/ 또는 ::v-deep 사용
(/deep/은 deprecated되어 현재는 동일하게 동작하지만 ::v-deep 사용을 권장)
: css가 동작하기 전에 사용하는 기능으로 css 문서 작성에 도움을 주는 도구
-> css의 color 값을 찾는 일, tag를 여닫는 일의 반복적인 작업을 programatically한 방식(변수, 함수, 상속 등 일반적인 프로그래밍 개념)을 사용하여 개선
대표적인 전처리기 : Sass, Less, Stylus
참고 : https://kdydesign.github.io/2019/05/12/css-preprocessor/