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 | ! Вместо $,! использовался как префикс переменной. Функциональность не изменится при использовании вместо $. |