일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 제네릭
- 타입좁히기
- react
- returnType
- 폰트적용하기
- 티스토리꾸미기
- 반복줄이기
- 타입스크립트
- 2022
- typescript
- const 단언문
- utilty type
- reactjs
- vue.js
- 개발콘텐츠
- javascript
- 리액트
- 레이아웃쪼개기
- CSS
- NonNullable
- 공통컴포넌트
- React Native
- JS console
- TSDoc
- 누구나 자료구조와 알고리즘
- Chart.js
- 커스텀
- 성능최적화
- click and drag
- React.js
- Today
- Total
몽땅뚝딱 개발자
[CSS] Sass(SCSS)란 본문
◽ Sass(Syntactically Awesome Style Sheets)란?
- 대표적인 CSS 전처리기 중 하나이다.
- CSS가 동작하기 전에 사용하는 기능으로 CSS Preprocessor라고 부른다.
- CSS 문법과 유사하지만 선택자의 중첩이나 조건문, 반복문 등을 사용하여 더 편리하게 작성할 수 있다.
- 웹에서는 직접 동작하지 않으므로 전처리기로 작성 후 CSS로 컴파일하는 방식으로 사용한다.
◽ SCSS(Sassy CSS)란?
- Sass의 3버전에서 새롭게 등장한 것으로, CSS와 거의 같은 문법으로 Sass 기능을 지원한다.
- {}(중괄호)와 ;(세미콜론)을 사용하는 점이 두드러진 차이이다.
◽ CSS로 컴파일하는 도구
- Webpack: 모듈 번들러
- Gulp: 빌드 자동화 도구
◽ Sass의 문법
- 변수(Variables): $를 사용하여 변수를 만들어 사용한다.
$font-stack: sans-serif;
$primary-color: black;
/* 변수 재할당도 가능하다. */
$font-color: $primary-color;
body {
font: 100% $font-stack;
color: $primary-color;
}
- 중첩(Nesting): CSS 선택자를 중첩할 수 있다.
div {
ul {
margin: 0;
padding: 0;
}
li {
display: inline-block;
}
}
- 상위선택자호환(Ampersand): 중첩에서 &
키워드는 상위(부모) 선택자를 참조하여 치환한다.
[예시 1.]
/* SCSS */
.btn {
position: absolute;
/* <div class="btn active">의 경우 */
&.active {
color: red;
}
}
/* CSS로 컴파일 */
.btn {
position: absolute;
}
.btn.active {
color: red;
}
[예시 2.]
/* SCSS */
.fs {
&-small { font-size: 12px; }
&-large { font-size: 16px; }
}
/* CSS로 컴파일 */
.fs-small {
font-size: 12px;
}
.fs-large {
font-size: 16px;
}
- 모듈화: 작은 조각으로 분리할 수 있다. sass 파일 이름 앞에 '_'가 붙은 경우 이를 CSS파일로 생성하지 않는다.
/* 파일이름: _base.scss */
$font-stack: Helvetica, sans-serif;
$primary-color: #333;
body {
font: 100% $font-stack;
color: $primary-color;
}
/* 파일이름: styles.scss */
/* 앞서 작성한 _base.sass파일을 사용할 수 있다. */
/* sass가 알아서 인식하므로 작성시에 파일확장자를 포함할 필요가 없다. */
@use 'base';
.inverse {
background-color: base.$primary-color;
color: white;
}
- Mixins: @mixin을 사용하면 사이트 전체에서 재사용하는 css 선언 그룹을 만들 수 있다.
@mixin theme($theme: DarkGray) {
background: $theme;
box-shadow: 0 0 1px reba($theme, .25);
color: #fff;
}
/*
css로 컴파일되면 아래와 같다.
.info {
background: DarkGray;
box-shadow: 0 0 1px rgba(169, 169, 169, 0.25);
color: #fff;
}
*/
.info {
@include theme;
}
.alert {
@include theme($theme: DarkRed);
}
.success {
@include theme($theme: black);
}
- 확장(Extend)/상속(Inheritance): @extend의 사용
%message-shared {
border: 1px solid #ccc;
padding: 10px;
color: #333;
}
.message {
@extend %message-shared;
}
.success {
@extend %message-shared;
border-color: green;
}
.error {
@extend %message-shared;
border-color: red;
}
- 주석의 compile 여부
// 이 주석은 sass에서만 출력된다.
/* 이 주석은 css로 컴파일 된다. */
출처 및 참조
[SassㆍSCSS] SASS 문법 3편 - 변수, !global, !default
개인적으로 공부한 내용을 정리하는 블로그로
잘못된 개념을 게시하지않도록 주의하고 있으나 오류가 있을 수 있습니다.
'Development > HTML · CSS' 카테고리의 다른 글
[HTML] 기본용어 및 마크업 시 주의사항 (0) | 2021.12.02 |
---|---|
[HTML/CSS] :nth-chlid(num) / :nth-of-type(num) (0) | 2021.11.27 |
[CSS] 선택자(Selector)란? (0) | 2021.11.04 |
[HTML/CSS] background-position (0) | 2021.09.24 |
[HTML/CSS] 반응형에서 공간이 밀릴 때 (0) | 2021.08.27 |