sass-site/source/documentation/interpolation.html.md.erb

154 lines
4.8 KiB
Plaintext
Raw Normal View History

2018-09-01 13:35:20 -07:00
---
title: Interpolation
table_of_contents: true
2018-09-01 13:35:20 -07:00
---
Interpolation can be used almost anywhere in a Sass stylesheet to embed the
result of a [SassScript expression][] into a chunk of CSS. Just wrap an
expression in `#{}` in any of the following places:
[SassScript expression]: ../syntax/structure#expressions
* [Selectors in style rules](../style-rules#interpolation)
* [Property names in declarations](../style-rules/declarations#interpolation)
* [Custom property values](../style-rules/declarations#custom-properties)
* [CSS at-rules](../at-rules/css#interpolation)
* [`@extend`s](../at-rules/extend#interpolation)
* [Plain CSS `@import`s](../at-rules/import#interpolation)
* [Quoted or unquoted strings](../values/strings#interpolation)
* [Special functions](../syntax/special-functions)
* [Plain CSS function names](../functions/css#interpolation)
* [Loud comments](../syntax/comments)
<% example do %>
@mixin corner-icon($name, $top-or-bottom, $left-or-right) {
.icon-#{$name} {
background-image: url("/icons/#{$name}.svg");
position: absolute;
#{$top-or-bottom}: 0;
#{$left-or-right}: 0;
}
2018-09-01 13:35:20 -07:00
}
@include corner-icon("mail", top, left);
===
@mixin corner-icon($name, $top-or-bottom, $left-or-right)
.icon-#{$name}
background-image: url("/icons/#{$name}.svg")
position: absolute
#{$top-or-bottom}: 0
#{$left-or-right}: 0
2018-09-01 13:35:20 -07:00
@include corner-icon("mail", top, right)
2018-09-01 13:35:20 -07:00
<% end %>
## In SassScript
<% impl_status dart: true, libsass: false, ruby: '4.0.0 (unreleased)' do %>
LibSass and Ruby Sass currently use an older syntax for parsing interpolation
in SassScript. For most practical purposes it works the same, but it can
behave strangely around [operators][]. See [this document][] for details.
2018-09-01 13:35:20 -07:00
[operators]: operators
[this document]: https://github.com/sass/language/blob/master/accepted/free-interpolation.md#old-interpolation-rules
2018-09-01 13:35:20 -07:00
<% end %>
Interpolation can be used in SassScript to inject SassScript into [unquoted
strings][]. This is particularly useful when dynamically generating names (for
example for animations), or when using [slash-separated values][]. Note that
interpolation in SassScript always returns an unquoted string.
[unquoted strings]: ../values/strings#unquoted
[slash-separated values]: ../operators/numeric#slash-separated-values
<% example do %>
@mixin inline-animation($duration) {
$name: inline-#{unique-id()};
2018-09-01 13:35:20 -07:00
@keyframes #{$name} {
@content;
}
2018-09-01 13:35:20 -07:00
animation-name: $name;
animation-duration: $duration;
animation-iteration-count: infinite;
}
2018-09-01 13:35:20 -07:00
.pulse {
@include inline-animation(2s) {
from { background-color: yellow }
to { background-color: red }
}
2018-09-01 13:35:20 -07:00
}
===
@mixin inline-animation($duration)
$name: inline-#{unique-id()}
2018-09-01 13:35:20 -07:00
@keyframes #{$name}
@content
2018-09-01 13:35:20 -07:00
animation-name: $name
animation-duration: $duration
animation-iteration-count: infinite
2018-09-01 13:35:20 -07:00
.pulse
@include inline-animation(2s)
from
background-color: yellow
to
background-color: red
2018-09-01 13:35:20 -07:00
<% end %>
<% fun_fact do %>
Interpolation is useful for injecting values into strings, but other than that
it's rarely necessary in SassScript expressions. You definitely *don't* need
it to just use a variable in a property value. Instead of writing `color:
#{$accent}`, you can just write `color: $accent`!
2018-09-01 13:35:20 -07:00
<% end %>
<% heads_up do %>
It's almost always a bad idea to use interpolation with numbers. Interpolation
returns unquoted strings that can't be used for any further math, and it
avoids Sass's built-in safeguards to ensure that units are used correctly.
2018-09-01 13:35:20 -07:00
Sass has powerful [unit arithmetic][] that you can use instead. For example,
instead of writing `#{$width}px`, write `$width * 1px`—or better yet, declare
the `$width` variable in terms of `px` to begin with. That way if `$width`
already has units, you'll get a nice error message instead of compiling bogus
CSS.
2018-09-01 13:35:20 -07:00
[unit arithmetic]: ../values/numbers#units
2018-09-01 13:35:20 -07:00
<% end %>
## Quoted Strings
In most cases, interpolation injects the exact same text that would be used if
the expression were used as a [property value][]. But there is one exception:
the quotation marks around quoted strings are removed (even if those quoted
strings are in lists). This makes it possible to write quoted strings that
contain syntax that's not allowed in SassScript (like selectors) and interpolate
them into style rules.
[property value]: ../style-rules/declarations
<% example do %>
.example {
unquoted: #{"string"};
}
===
.example
unquoted: #{"string"}
2018-09-01 13:35:20 -07:00
<% end %>
<% heads_up do %>
While it's tempting to use this feature to convert quoted strings to unquoted
strings, it's a lot clearer to use the [`unquote()` function][]. Instead of
`#{$string}`, write `unquote($string)`!
2018-09-01 13:35:20 -07:00
2018-10-23 17:45:14 -07:00
[`unquote()` function]: ../functions/string#unquote
2018-09-01 13:35:20 -07:00
<% end %>