Sass - Синтаксис

В этой главе мы изучим SASS Syntax. SASS поддерживает два синтаксиса, а именноSCSS и Indented syntax.

  • В SCSS (Sassy CSS)является расширением синтаксиса CSS. Это означает, что каждый действительный CSS также является действительным SCSS. SCSS значительно упрощает работу с большими таблицами стилей и может распознавать синтаксис производителя, многие файлы CSS и SCSS используют расширение.scss.

  • Indented - Это старый синтаксис, иногда его просто называют SASS. Используя эту форму синтаксиса, можно кратко написать CSS. Файлы SASS используют расширение.sass.

Синтаксис с отступом SASS

SASS Синтаксис с отступом или просто SASS является альтернативой синтаксису SCSS на основе CSS.

  • Он использует отступы, а не{ и } для разграничения блоков.

  • Для разделения операторов вместо точки с запятой (;) используются символы новой строки .

  • Объявление свойства и селекторы должны быть размещены в отдельной строке, а операторы внутри{ и }должен быть размещен на новой строке и с отступом .

Например, рассмотрим следующий код 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 следить за файлом и обновлять CSS всякий раз, когда файл SASS изменяется, используя следующую команду:

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. Предупреждение будет отображаться, если вы используете этот синтаксис, и он будет удален в более поздних версиях. Некоторые из старых синтаксисов показаны в следующей таблице.

С. Нет. Оператор и описание
1

=

Он использовался вместо: при установке переменных и свойств в значения SassScript.

2

||=

Он использовался вместо: всякий раз, когда вы назначаете значение по умолчанию для переменной.

3

!

Вместо $,! использовался как префикс переменной. Функциональность не изменится при использовании вместо $.