기본문법 매뉴얼

번역하고 싶은 언어를 선택해 주세요.

CSS 편집 툴 사용 방법(SCSS)

SCSS를 이용하여 CSS파일을 효율적으로 관리할 수 있습니다.

* CSS 중첩

css를 중첩방식을 통하여 간단하게 작성할 수 있습니다.

style.scss

#navbar {
  width: 80%;
  height: 23px;

  ul { list-style-type: none; }
  li {
    float: left;
    a { font-weight: bold; }
  }
}

style.css

#navbar {
  width: 80%;
  height: 23px;
}

#navbar ul {
  list-style-type: none;
}

#navbar li {
  float: left;
}

#navbar li a {
  font-weight: bold;
}

* CSS 속성 중첩

css의 속성을 중첩방식을 통하여 간단하게 작성할 수 있습니다.

style.scss

.fakeshadow {
  border: {
    style: solid;
    left: {
      width: 4px;
      color: #888;
    }
    right: {
      width: 2px;
      color: #ccc;
    }
  }
}

style.css

.fakeshadow {
  border-style: solid;
  border-left-width: 4px;
  border-left-color: #888;
  border-right-width: 2px;
  border-right-color: #ccc;
}

* 상위 참조

&:를 이용해서 상위 속성을 참조하여 셀렉터의 속성을 정의할 수 있습니다.

style.scss

a {
  color: #ce4dd6;
  &:hover { color: #ffb3ff; }
  &:visited { color: #c458cb; }
}

style.css

a {
  color: #ce4dd6;
}

a:hover {
	color: #ffb3ff;
}

a:visited {
	color: #c458cb;
}

* 변수

자주 사용되는 값을 변수로 선언하여 반복사용이 가능합니다.
변수는 색상, 숫자, 텍스트 등 CSS속성에 허용되는 모든 값을 가질 수 있습니다.

style.scss

$main-color: #ce4dd6;
$style: solid;

#navbar {
  border-bottom: {
    color: $main-color;
    style: $style;
  }
}

a {
  color: $main-color;
  &:hover { border-bottom: $style 1px; }
}

style.css

#navbar {
  border-bottom-color: #ce4dd6;
  border-bottom-style: solid;
}

a {
  color: #ce4dd6;
}

a:hover {
  border-bottom: solid 1px;
}

* 변수의 변환

간단한 수식 및 미리 정의된 함수를 이용하여 변수값을 다양하게 활용할 수 있습니다.

style.scss

#navbar {
  $navbar-width: 800px;
  $items: 5;
  $navbar-color: #ce4dd6;

  width: $navbar-width;
  border-bottom: 2px solid $navbar-color;

  li {
    float: left;
    width: $navbar-width/$items - 10px;		// 가로크기를 항목수를 나눈다움 10px을 뺌

    background-color:
      lighten($navbar-color, 20%);			// 20% 밝게
    &:hover {
      background-color:
        lighten($navbar-color, 10%);		// 10% 밝게
    }
  }
}

style.css

#navbar {
  width: 800px;
  border-bottom: 2px solid #ce4dd6;
}

#navbar li {
	float: left;
	width: 150px;
	background-color: #e5a0e9;
}

#navbar li:hover {
	background-color: #d976e0;
}

* 속성 이름값

#{}를 이용하여 속성이름에 특정한 값을 반복하여 사용할 수 있습니다.

style.scss

$vert: top;
$horz: left;
$radius: 10px;

.rounded-#{$vert}-#{$horz} {
  border-#{$vert}-#{$horz}-radius: $radius;
  -moz-border-radius-#{$vert}#{$horz}: $radius;
  -webkit-border-#{$vert}-#{$horz}-radius: $radius;
}

style.css

.rounded-top-left {
  border-top-left-radius: 10px;
  -moz-border-radius-topleft: 10px;
  -webkit-border-top-left-radius: 10px;
}

* 믹스 인

mixin을 이용하여 미리 정의된 스타일을 반복적으로 사용할 수 있습니다.
@mixin으로 정의하여, @include로 사용합니다.

style.scss

@mixin rounded-top-left {
  $vert: top;
  $horz: left;
  $radius: 10px;

  border-#-#-radius: $radius;
  -moz-border-radius-##: $radius;
  -webkit-border-#-#-radius: $radius;
}

#navbar li { @include rounded-top-left; }
#footer { @include rounded-top-left; }

style.css

#navbar li {
  border-top-left-radius: 10px;
  -moz-border-radius-topleft: 10px;
  -webkit-border-top-left-radius: 10px;
}

#footer {
  border-top-left-radius: 10px;
  -moz-border-radius-topleft: 10px;
  -webkit-border-top-left-radius: 10px;
}

* 인수

mixin 사용시 함수처럼 인수를 설정하여 다양한 값으로 사용이 가능하다.

style.scss

@mixin rounded($vert, $horz, $radius: 10px) {
  border-#-#-radius: $radius;
  -moz-border-radius-##: $radius;
  -webkit-border-#-#-radius: $radius;
}

#navbar li { @include rounded(top, left); }
#footer { @include rounded(top, left, 5px); }
#sidebar { @include rounded(top, left, 8px); }

style.css

#navbar li {
  border-top-left-radius: 10px;
  -moz-border-radius-topleft: 10px;
  -webkit-border-top-left-radius: 10px;
}

#footer {
  border-top-left-radius: 5px;
  -moz-border-radius-topleft: 5px;
  -webkit-border-top-left-radius: 5px;
}

#sidebar {
  border-top-left-radius: 8px;
  -moz-border-radius-topleft: 8px;
  -webkit-border-top-left-radius: 8px;
}

* 익스텐드

extend를 사용하여 미리 구성된 속성들을 반복하여 사용할 수 있다.

style.scss

%button {
	display:inline-block; *display:inline; *zoom:1;
	margin:0; padding:6px 12px; font-size:14px; text-align:center;
}

.red_button {
	@extend %button;
	color:#fff; background:#ed1c24;
}
.green_button {
	@extend %button;
	color:#fff; background:#3ec134;
	}
}
.blue_button {
	@extend %button;
	color:#fff; background:#266ac8;
}

style.css

.red_button {
	display:inline-block; *display:inline; *zoom:1;
	margin:0; padding:6px 12px; font-size:14px; text-align:center;
	color:#fff; background:#ed1c24;
}
.green_button {
	display:inline-block; *display:inline; *zoom:1;
	margin:0; padding:6px 12px; font-size:14px; text-align:center;
	color:#fff; background:#3ec134;
	}
}
.blue_button {
	display:inline-block; *display:inline; *zoom:1;
	margin:0; padding:6px 12px; font-size:14px; text-align:center;
	color:#fff; background:#266ac8;
}