I'm trying out PostCss and trying to find comparable features to Sass. The one feature I'm stuck on is Sass-like functions.
Here's my function is Sass:
// Variables.scss
$columns: 12; // Grid columns
$max-width: 1200px; // Grid max width
// Function.scss
@function grid($cols,$to-px:false) {
@if ($to-px == false) { @return ($cols / $columns) * 100% };
@return round(($max-width / $columns) * $cols);
}
// style.scss
.class {
width: grid(3);
}
.class2 {
width: grid(3,true);
}
// outputs to:
// style.css
.class {
width: 25%;
}
.class2 {
width: 300px;
}
In PostCSS can I write a function like this that returns a single CSS value?
PostCSS Sass lets you use Sass as a PostCSS plugin.
PostCSS can do the same work as preprocessors like Sass, Less, and Stylus. But PostCSS is modular, 3-30 times faster, and much more powerful.
PostCSS is a tool for transforming CSS with JS plugins. These plugins can support variables and mixins, transpile future CSS syntax, inline images, and more; Sass: Syntactically Awesome Style Sheets. Sass is an extension of CSS3, adding nested rules, variables, mixins, selector inheritance, and more.
PostCSS is a highly useful tool that has been around for a while now. It encourages you to write more of plain CSS and allows you to use or write your own powerful plugins to transform it. Learning this tool, or at least becoming more aware of its uses, will improve your front-end workflow in 2019.
I'm not aware of an existing PostCSS plugin that allows you to use @function
within CSS, but one may be out there. postcss-define-function
provides some comparable functionalily, so maybe give that a look.
If what you need doesn't exist, it should be possible to write one, using, PostCSS's atRule class (and likely some others).
However, writing a plugin like that would be pretty complicated, and is also sort of antithetical to how PostCSS encourages you to author your styles.
One of the main benefits of PostCSS is that it lets you manipulate your styles with JavaScript; rather than trying to write functions in CSS, consider writing them in JavaScript. postcss-functions
looks like it does just this, allowing you to expose functions—written in JavaScript—to be used within your CSS. Your given example could look something like this:
require('postcss-functions')({
functions: {
grid:(cols, totalCols, maxWidth, toPx = false) {
return toPx
? `${Math.round(maxWidth / cols * totalCols)}px`
: `${cols / totalCols * 100}%`
}
}
});
Which should allow you to write CSS like so:
.class {
width: grid(3, 12, 1200);
}
.class2 {
width: grid(3, 12, 1200, true);
}
.class {
width: 25%;
}
.class2 {
width: 300px;
}
If that doesn't work exactly as you expect it to, you can always make a pull request to the project, or write your own plugin.
Hope that helps!
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With