sass-site/source/documentation/breaking-changes/strict-unary.liquid

69 lines
2.1 KiB
Plaintext
Raw Normal View History

2023-05-25 00:07:53 +02:00
---
2023-05-26 00:24:38 +02:00
title: 'Breaking Change: Strict Unary Operators'
2023-05-25 00:07:53 +02:00
introduction: >
Sass has historically allowed `-` and `+` to be used in ways that make it
ambiguous whether the author intended them to be a binary or unary operator.
This confusing syntax is being deprecated.
---
2023-05-26 20:32:08 +02:00
{% markdown %}
2023-05-31 18:02:42 +02:00
How is this property compiled?
2023-05-26 20:32:08 +02:00
{% endmarkdown %}
2023-05-25 00:07:53 +02:00
2023-05-26 20:32:08 +02:00
{% codeExample 'strict-unary', false %}
2023-05-31 18:02:42 +02:00
$size: 10px;
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
div {
margin: 15px -$size;
}
===
$size: 10px
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
div
margin: 15px -$size
2023-05-25 00:07:53 +02:00
{% endcodeExample %}
2023-05-26 20:32:08 +02:00
{% markdown %}
2023-05-31 18:02:42 +02:00
Some users might say "the `-` is attached to `$size`, so it should be `margin:
20px -10px`". Others might say "the `-` is between `20px` and `$size`, so it
should be `margin: 5px`." Sass currently agrees with the latter opinion, but
the real problem is that it's so confusing in the first place! This is a
natural but unfortunate consequence of CSS's space-separated list syntax
combined with Sass's arithmetic syntax.
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
That's why we're moving to make this an error. In the future, if you want to
use a binary `-` or `+` operator (that is, one that subtracts or adds two
numbers), you'll need to put whitespace on both sides or on neither side:
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
* Valid: `15px - $size`
* Valid: `(15px)-$size`
* Invalid: `15px -$size`
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
If you want to use a unary `-` or `+` operator as part of a space-separated
list, you'll (still) need to wrap it in parentheses:
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
* Valid: `15px (-$size)`
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
## Transition Period
2023-05-25 00:07:53 +02:00
{% compatibility 'dart: 1.55.0', 'libsass: false', 'ruby: false' %}{% endcompatibility %}
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
We'll make this an error in Dart Sass 2.0.0, but until then it'll just emit a
deprecation warning.
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
{% render 'documentation/snippets/silence-deprecations' %}
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
## Automatic Migration
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
You can use [the Sass migrator] to automatically update your stylesheets to
add a space after any `-` or `+` operators that need it, which will preserve
the existing behavior of these stylesheets.
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
[the Sass migrator]: https://github.com/sass/migrator#readme
2023-05-25 00:07:53 +02:00
2023-05-31 18:02:42 +02:00
```shellsession
$ npm install -g sass-migrator
$ sass-migrator strict-unary **/*.scss
```
2023-05-26 20:32:08 +02:00
{% endmarkdown %}