NHacker Next
  • new
  • past
  • show
  • ask
  • show
  • jobs
  • submit
CSSnano (cssnano.github.io)
seu 121 days ago [-]
This is all great, but while the internet is filled with auto-playing videos and invokes to external scripts from google, meta, amazon and who knows where, the example on this page is about saving... 148 bytes? Does minifying CSS really make a big difference, in the end? I'm guessing that a page with a serious CSS payload (say, over 100k) already has more serious weight problem elsewhere.
tosh 121 days ago [-]
The main problem with CSS is that it is "render blocking". If you want the user to see stuff sooner you have to make the CSS smaller and/or serve it faster (e.g. inline it to avoid another request).
agos 121 days ago [-]
how sooner will I see the stuff if I use this tool?
tosh 121 days ago [-]
I haven't measured yet but my guess would be that on current devices 99% of the CSS size saving matters for making the transfer of the CSS faster over the network (and that the speed up in constructing the CSS Object Model is negligible).

=> Users with low bandwidth and/or flakey connection benefit

Happy to learn otherwise though!

hawski 121 days ago [-]
CSS is a high level language used very often as a low level one. The styling doesn't use any "cascading" and everything is repeated all the time. In this context minifying can make a difference. But either way it is not among my favorites.
120 days ago [-]
littlestymaar 121 days ago [-]
Does minifying make any difference if you're gzip-ing it in-flight anyway?

Edit: I mean, in the real world. Obviously in their example gzip does pretty much nothing since there's so little content, which leave very little room for compression.

mixmastamyk 121 days ago [-]
Recently tested compressing picocss, one version was 80k or something. gzipd to 16k, +min, 13k. Brotli 13k, +min 10k.

So maybe another thirty percent, probably from removing comments etc, not just whitespace.

littlestymaar 120 days ago [-]
Thanks.
PROMISE_237 121 days ago [-]
[dead]
theandrewbailey 121 days ago [-]
CSS is text based, so it should be gzip (or brotli) compressed. Minifying something isn't as effective as compressing it. You could do both, but the difference is small.
zamadatix 120 days ago [-]
The numbers above are already referring to the gzipped raw vs gzipped minified.
agos 121 days ago [-]
never mind a "big" difference, I would be surprised if it made a "measurable" difference
paulddraper 121 days ago [-]
1. The README example is 54% reduction (for gzipped result).

2. CSS often blocks page render, to avoid flashing unstyled content.

3. "Tree-shaking" CSS is often difficult or impossible.

Many (most?) CSS libraries minify their outputs...Bootstrap, Materialize, Semantic UI, Foundation.

emmacharp 120 days ago [-]
I started linking component stylesheets directly in the component HTML, de facto eliminating unused CSS from the output. HTTP3 provides performance gains we can benefit from by serving multiple CSS files "just-in-time".

I've had great results since. No more unused CSS. No more minifying nor bundling. What you write is what you get. It's liberating! Hehe.

paulddraper 120 days ago [-]
That's good. Also, that doesn't work for a library where you're using one of six button styles.
replete 121 days ago [-]
LightningCSS[0] is better and faster, unless something has changed.

https://lightningcss.dev/

fallingsquirrel 121 days ago [-]
We tried LightningCSS and it gave buggy output for us because it doesn't keep track of property ordering. I wouldn't use it until that's fixed.

https://github.com/parcel-bundler/lightningcss/issues/547

https://github.com/parcel-bundler/lightningcss/issues/572

replete 121 days ago [-]
Unfortunate to see these issues open for over a year, especially as previous versions did not do this. Thanks for the heads up
GaggiX 121 days ago [-]
Just seeing how bad the site renders on my phone I wouldn't trust it.
replete 118 days ago [-]
I've used it on a few projects successfully. The property ordering thing mentioned in other comments though is good to be aware of. It's not difficult to switch out for css nano if that is the case. The important feature for me was being able to target a browserlist string and flatten CSS nesting
ycombinatrix 121 days ago [-]
Looks fine on my phone.
GaggiX 121 days ago [-]
On my phone it has some extreme borders and in many lines it can only fit one single word.
muhrizqiardi 121 days ago [-]
It works fine for me--but I wonder if it has to do with the exessive shadow/glow effect?
fenomas 121 days ago [-]
TFA and GP are CSS minimizers - nothing to do with styles per se.
weinzierl 121 days ago [-]
Is there a tool that can remove unused CSS while considering static HTML?

What I have in mind is a tool that I throw a CSS file and a bunch of static HTML files at, it will try to apply each CSS rule to the HTML like a browser would and remove all the rules that don't apply.

I don't expect it to ascertain if a rule had visible effects. I also don't expect it to consider JavaScript. Just plain CSS and static HTML. It doesn't look to me like CSSnano or LighteningCSS could do that.

csande17 121 days ago [-]
https://purgecss.com/ does this, kind of -- it used to be recommended by Tailwind back when Tailwind shipped a giant zip-bomb stylesheet of every possible property/value combination by default. I don't think it does the more complicated browser-like analysis you mention, though; it might just check whether class names appear in your HTML using a regex search.

The AMP WordPress plugin also does something like this IIRC (to try and fit stylesheets into AMP's size limit) but the tooling for it might be written in PHP.

alberth 121 days ago [-]
How do you remove the unused CSS?

https://purifycss.online/

Above is a nice online version of Purify. But it just seems to minimize the CSS, and doesn’t delete the unused CSS.

craftkiller 121 days ago [-]
I wrote that for my company ~3 jobs ago, except instead of working only on static HTML, it would: for a small percentage of our traffic loop in the background processing a couple CSS selectors at a time, adding CSS selectors that matched to a bloom filter that would be occasionally POSTed back to the server. Then I'd parse through our logs, pulling out the bloom filters, and comparing them to our CSS rules to find unused rules. It wasn't perfect so it required manually checking before deleting CSS rules but it went a long way towards flagging potentially unused CSS rules.
stigok 121 days ago [-]
This would work nicely with static HTML, indeed. But once you have some JavaScript i.e. dynamic HTML, it won't work reliably anymore. Worse, it might even give you a list of manually curated CSS properties to "allow list".
Izkata 121 days ago [-]
Waaay back there used to be a Firebug plugin that would monitor which CSS was ever used as you interacted with a page. Worked great for exactly these dynamic pages - I was using it with React for a few years before Quantum killed the XUL addons.

I'd forgotten about it and am now wondering if anyone made a replacement...

Ayesh 121 days ago [-]
Chrome Dev tools has this feature. It's not as useful because when you navigate to another page, it resets the used CSS rules.
merb 121 days ago [-]
this is incorrect.

the only thing that does not work is generating the css class like:

var x = 'hase-';

var t = x + 'danger'

which is an antipattern. (it can even happen inside java, c#, whatever language you use and it is still an antipattern)

phito 121 days ago [-]
Can you please elaborate why it is an antipattern? I'm not sure I understand.
sionisrecur 121 days ago [-]
At least regarding tailwindcss, it checks your code to filter out unused css classes. So it is recommended to have full class names in the code instead of constructing them by concatenating strings. So if you have a variable `buttonColor` that can be `red` or `blue` it is better to do something like

    switch(buttonColor) {
        'red': return 'button-red';
        'blue': return 'button-blue';
    }
over

    return 'button-' + buttonColor;
merb 121 days ago [-]
if you are in a big project and want to refactor classes the string concatenation pattern gets extremely painful, it’s even worse when it’s done on the server and on the frontend. At some point you will have trouble removing your classes. My company did this a lot and know we struggle to clean it up since basically all classes are used somewhere. What we do is basically use purgecss and than diff it and look for all occurrences that got removed which will take us a few months.
phito 120 days ago [-]
Oh ok it was about concatenation, not just this example case. Got it, thank you!
PROMISE_237 121 days ago [-]
[dead]
a-french-anon 121 days ago [-]
Eh, even on this example, most of the gains come from simply removing the comments (something that can easily be done with `cpp -E -P <in.css >out_cpp.css` or regexps since CSS doesn't allow comment nesting) on most UNIXes.

Here's a more complete result adding brotli and the aforementioned cpp version:

  $ gdu -b *.css *.css.gz *.css.br | awk '{if (NR % 3 == 1) {ref = $1; print} else print $0, "(" $1 - ref ")"}'
  623 in.css
  197 out.css (-426)
  355 out_cpp.css (-268)
  345 in.css.gz
  185 out.css.gz (-160)
  235 out_cpp.css.gz (-110)
  284 in.css.br
  141 out.css.br (-143)
  177 out_cpp.css.br (-107)
sionisrecur 121 days ago [-]
cpp as in a C preprocesor? That's a neat trick. I guess it removes what looks like /* comments */ and leaves the rest alone?
no_wizard 121 days ago [-]
cssnano has had some complicated ownership turnover[0], I'm glad to see someone took the mantle again though.

I do find that CSSO[1] with structural optimizations can be more effective still, perhaps that will be less true overtime though.

I think once lightning CSS is more stable (in particular, some bugs are addressed around ordering) it will be the clear winner in this space though.

[0]: https://github.com/cssnano/cssnano/issues/833

[1]: https://github.com/css/csso

lofaszvanitt 121 days ago [-]
People need more things that can be discovered. Everyone reinvents the wheel rn.
Inviz 121 days ago [-]
Why keep background-position, if background overrides it anyway?
troupo 121 days ago [-]
Can't say exactly why, but I had this suggested by IDEA (?) as well. Could be because background is a kitchen-sink of everything there is in a background including several different DSLs for gradients and such. So it makes sense to keep just background-position if there's a simpler background: the browser will spend less time processing it.

Whether that is measurable is a different story :)

Inviz 119 days ago [-]
Yeah though within context of a single rule keeping that prop is pure overhead
Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact
Rendered at 08:16:46 GMT+0000 (Coordinated Universal Time) with Vercel.