44 lines
1.3 KiB
Plaintext
Raw Normal View History

---
title: "@debug"
introduction: >
2023-05-30 16:27:01 -04:00
Sometimes its useful to see the value of a
[variable](/documentation/variables) or
[expression](/documentation/syntax/structure#expressions) while youre
developing your stylesheet. Thats what the `@debug` rule is for: its written
`@debug <expression>`, and it prints the value of that expression, along with
the filename and line number.
---
2023-05-30 16:27:01 -04:00
{% codeExample 'debug', false %}
2023-05-30 17:23:34 -04:00
@mixin inset-divider-offset($offset, $padding) {
$divider-offset: (2 * $padding) + $offset;
@debug "divider offset: #{$divider-offset}";
2023-05-30 17:23:34 -04:00
margin-left: $divider-offset;
width: calc(100% - #{$divider-offset});
}
===
@mixin inset-divider-offset($offset, $padding)
$divider-offset: (2 * $padding) + $offset
@debug "divider offset: #{$divider-offset}"
2023-05-30 17:23:34 -04:00
margin-left: $divider-offset
width: calc(100% - #{$divider-offset})
{% endcodeExample %}
{% markdown %}
2023-05-30 17:23:34 -04:00
The exact format of the debug message varies from implementation to
implementation. This is what it looks like in Dart Sass:
2023-05-30 17:23:34 -04:00
```
test.scss:3 Debug: divider offset: 132px
```
2023-05-30 16:27:01 -04:00
{% endmarkdown %}
{% funFact %}
2023-05-30 17:23:34 -04:00
You can pass any value to `@debug`, not just a string! It prints the same
representation of that value as the [`meta.inspect()` function][].
2023-05-30 17:23:34 -04:00
[`meta.inspect()` function]: /documentation/modules/meta#inspect
{% endfunFact %}