Sass-구문

이 장에서는 SASS에 대해 공부합니다. Syntax. SASS는 두 가지 구문을 지원합니다.SCSSIndented syntax.

  • 그만큼 SCSS (Sassy CSS)CSS 구문의 확장입니다. 이것은 모든 유효한 CSS도 유효한 SCSS임을 의미합니다. SCSS를 사용하면 큰 스타일 시트를 훨씬 쉽게 유지 관리 할 수 ​​있으며 공급 업체별 구문을 인식 할 수 있습니다. 많은 CSS 및 SCSS 파일은 확장명을 사용합니다..scss.

  • Indented − 이것은 오래된 구문이며 때로는 다음과 같이 호출됩니다. SASS. 이러한 형태의 구문을 사용하여 CSS를 간결하게 작성할 수 있습니다. SASS 파일은 확장자를 사용합니다..sass.

SASS 들여 쓰기 구문

SASS 들여 쓰기 구문 또는 SASS는 CSS 기반 SCSS 구문의 대안입니다.

  • 대신 들여 쓰기를 사용합니다.{} 블록을 구분합니다.

  • 문을 구분하기 위해 세미콜론 (;) 대신 개행 문자 를 사용합니다 .

  • 속성 선언 및 선택기는에 위치해야 자신의 라인 내에서 문을{}새 줄 에 배치 하고 들여 쓰기 해야합니다 .

예를 들어, 다음 SCSS 코드를 고려하십시오.

.myclass {
   color = red;
   font-size = 0.2em;
}

그만큼 indented구문은 이전 구문으로 새 Sass 파일에서 사용하지 않는 것이 좋습니다. 이 파일을 사용하면 우리가 사용한 것처럼 CSS 파일에 오류가 표시됩니다.= 속성과 변수를 설정하는 대신.

다음 명령을 사용하여 위의 주어진 코드를 컴파일하십시오-

sass --watch C:\ruby\lib\sass\style.scss:style.css

다음으로 위의 명령을 실행합니다. 아래와 같이 style.css 파일에 오류가 표시됩니다.

Error: Invalid CSS after "  color = red": expected "{", was ";"
      on line 2 of C:\ruby\lib\sass\style17.scss

1:.myclass {
2:   color = red;
3:   font-size = 0.2em;
4:}

SASS의 구문 차이

대부분의 CSS 및 SCSS 구문은 SASS에서 완벽하게 작동합니다. 그러나 다음 섹션에서 설명하는 몇 가지 차이점이 있습니다.

속성 구문

CSS 속성은 두 가지 방법으로 선언 할 수 있습니다.

  • 속성은 CSS와 유사하게 선언 할 수 있지만 semicolon(;).

  • colon(:) 모든 속성 이름에 접두사가 붙습니다.

예를 들어, 다음과 같이 쓸 수 있습니다.

.myclass
   :color red
   :font-size 0.2em

기본적으로 위의 두 가지 방법 (세미콜론이없는 속성 선언과 속성 이름 앞에 콜론이 추가됨)을 사용할 수 있습니다. 그러나 : property_syntax 옵션 을 사용할 때 하나의 속성 구문 만 지정할 수 있습니다 .

여러 줄 선택기

들여 쓰기 구문에서 선택자는 다음에 나타날 때마다 줄 바꿈에 배치 할 수 있습니다. commas.

다음 예제는 SCSS 파일에서 여러 줄 선택기의 사용을 설명합니다-

<html>
   <head>
      <title>Multiline Selectors</title>
      <link rel = "stylesheet" type = "text/css" href = "style.css" />
      <link rel = "stylesheet" href = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
      <script src = "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
   </head>
   
   <body>
      <h2>Example using Multiline Selectors</h2 >
      <p class = "class1">Welcome to Tutorialspoint!!!</p>
      <p class = "class2">SASS stands for Syntactically Awesome Stylesheet...</p>
   </body>
</html>

다음으로 style.scss 파일을 생성합니다 . .scss 확장자에 유의하십시오 .

style.scss

.class1,
.class2{
   color:red;
}

다음 명령을 사용하여 SASS에 파일을 감시하고 SASS 파일이 변경 될 때마다 CSS를 업데이트하도록 지시 할 수 있습니다.

sass --watch C:\ruby\lib\sass\style.scss:style.css

다음으로 위의 주어진 명령을 실행 하면 다음 코드로 style.css 파일이 자동으로 생성 됩니다.

생성 된 style.css 는 다음과 같습니다.

style.css

.class1,
.class2 {
   color: red;
}

산출

위의 코드가 어떻게 작동하는지보기 위해 다음 단계를 수행해 보겠습니다.

  • 위에 주어진 html 코드를 multiline_selectors .html 파일 에 저장하십시오 .

  • 브라우저에서이 HTML 파일을 열면 아래와 같이 출력이 표시됩니다.

코멘트

주석은 전체 줄을 차지하고 그 아래에 중첩 된 모든 텍스트를 묶습니다. 들여 쓰기 구문에서 줄 기반입니다. 주석에 대한 자세한 내용은이 링크를 참조하십시오 .

@수입

SASS에서 @import지시문은 따옴표를 사용하거나 사용하지 않고 작성할 수 있습니다. SCSS와 달리 따옴표와 함께 사용해야합니다.

예를 들어, SCSS에서 @import 지시문은 다음과 같이 사용할 수 있습니다.

@import "themes/blackforest";
@import "style.sass";

이것은 SASS에서 다음과 같이 작성할 수 있습니다.

@import themes/blackforest
@import fontstyle.sass

Mixin 지시어

SASS는 다음과 같은 지시문의 속기를 지원합니다. @mixin@include. 대신에@mixin@include 당신이 사용할 수있는 =+ 입력이 덜 필요하고 코드를 더 간단하고 쉽게 읽을 수 있습니다.

예를 들어, mixin 지시문을 다음과 같이 작성할 수 있습니다.

=myclass
   font-size: 12px;
p
   +myclass

위의 주어진 코드는-

@mixin myclass
   font-size: 12px;
p
   @include myclass

사용되지 않는 구문

SASS는 일부 이전 구문의 사용을 지원합니다. 그러나 SASS에서이 구문을 사용하는 것은not recommended. 이 구문을 사용하면 경고가 표시되고 이후 버전에서 제거됩니다. 다음 표에는 이전 구문 중 일부가 나와 있습니다.

S. 아니. 연산자 및 설명
1

=

변수와 속성을 SassScript의 값으로 설정할 때 대신 사용되었습니다.

2

||=

변수의 기본값을 할당 할 때마다 : 대신 사용되었습니다.

!

대신에 $, ! was used as variable prefix. Functionality will not be changed when it is used instead of $.