sass-site/source/documentation/syntax/special-functions.md
2023-06-22 15:11:18 -04:00

4.9 KiB
Raw Blame History

title table_of_contents introduction
Special Functions true CSS defines many functions, and most of them work just fine with Sasss normal function syntax. Theyre parsed as function calls, resolved to [plain CSS functions](/documentation/at-rules/function/#plain-css-functions), and compiled as-is to CSS. There are a few exceptions, though, which have special syntax that cant just be parsed as a [SassScript expression](/documentation/syntax/structure#expressions). All special function calls return [unquoted strings](/documentation/values/strings#unquoted).

url()

The url() function is commonly used in CSS, but its syntax is different than other functions: it can take either a quoted or unquoted URL. Because an unquoted URL isn't a valid SassScript expression, Sass needs special logic to parse it.

If the url()'s argument is a valid unquoted URL, Sass parses it as-is, although interpolation may also be used to inject SassScript values. If it's not a valid unquoted URL—for example, if it contains variables or function calls—it's parsed as a normal plain CSS function call.

{% codeExample 'url' %} $roboto-font-path: "../fonts/roboto";

@font-face { // This is parsed as a normal function call that takes a quoted string. src: url("#{$roboto-font-path}/Roboto-Thin.woff2") format("woff2");

  font-family: "Roboto";
  font-weight: 100;

}

@font-face { // This is parsed as a normal function call that takes an arithmetic // expression. src: url($roboto-font-path + "/Roboto-Light.woff2") format("woff2");

  font-family: "Roboto";
  font-weight: 300;

}

@font-face { // This is parsed as an interpolated special function. src: url(#{$roboto-font-path}/Roboto-Regular.woff2) format("woff2");

  font-family: "Roboto";
  font-weight: 400;

}

$roboto-font-path: "../fonts/roboto"

@font-face // This is parsed as a normal function call that takes a quoted string. src: url("#{$roboto-font-path}/Roboto-Thin.woff2") format("woff2")

  font-family: "Roboto"
  font-weight: 100

@font-face // This is parsed as a normal function call that takes an arithmetic // expression. src: url($roboto-font-path + "/Roboto-Light.woff2") format("woff2")

  font-family: "Roboto"
  font-weight: 300

@font-face // This is parsed as an interpolated special function. src: url(#{$roboto-font-path}/Roboto-Regular.woff2) format("woff2")

  font-family: "Roboto"
  font-weight: 400

{% endcodeExample %}

element(), progid:...(), and expression()

{% compatibility 'dart: "<1.40.0"', 'libsass: false', 'ruby: false', 'feature: "calc()"' %} LibSass, Ruby Sass, and versions of Dart Sass prior to 1.40.0 parse calc() as special syntactic function like element().

Dart Sass versions 1.40.0 and later parse calc() as a calculation.

{% endcompatibility %}

{% compatibility 'dart: ">=1.31.0 <1.40.0"', 'libsass: false', 'ruby: false', 'feature: "clamp()"' %} LibSass, Ruby Sass, and versions of Dart Sass prior to 1.31.0 parse clamp() as a plain CSS function rather than supporting special syntax within it.

Dart Sass versions between 1.31.0 and 1.40.0 parse clamp() as special syntactic function like element().

Dart Sass versions 1.40.0 and later parse clamp() as a calculation.

{% endcompatibility %}

The element() function is defined in the CSS spec, and because its IDs could be parsed as colors, they need special parsing.

expression() and functions beginning with progid: are legacy Internet Explorer features that use non-standard syntax. Although they're no longer supported by recent browsers, Sass continues to parse them for backwards compatibility.

Sass allows any text in these function calls, including nested parentheses. Nothing is interpreted as a SassScript expression, with the exception that interpolation can be used to inject dynamic values.

{% codeExample 'element' %} $logo-element: logo-bg;

.logo { background: element(##{$logo-element}); }

$logo-element: logo-bg

.logo background: element(##{$logo-element}) {% endcodeExample %}