- From: Lea Verou via GitHub <sysbot+gh@w3.org>
- Date: Wed, 15 Sep 2021 17:28:26 +0000
- To: public-css-archive@w3.org
LeaVerou has just created a new issue for https://github.com/w3c/csswg-drafts: == [css-conditional-4] Rename @when to @if == The reasoning for using `@when` over `@if` is [that `@if` clashes with Sass](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-221669910), a widely used CSS preprocessor. However, there is a lot of pushback against this decision (and general philosophy) in #112: [@Marat-Tanalin (1)](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-221681433): > Fwiw, in the past, a SASS developer said at www-style that existing features of SASS should **not** be considered as limitations for new CSS features in any way: > > if a potential new CSS feature is conflicting with an existing SASS feature, then the **latter** could just be changed. [@Marat-Tanalin (2)](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-221726933): > > Yeah, Sass usage does not trump CSS. But there's also no reason to be hostile to the developer community when we can easily avoid such. > > Replacing the clear straightforward keyword widely used in almost all languages with an invented more-or-less similar one is actually probably not that _easy_. > > At the same time, SASS (as well as any other preprocessor) could really easily rename its `@if` or just transparently convert something like `@css-if` or `@native-if` to native CSS `@if`. That’s not a CSS problem at all. > > CSSWG decisions should probably not be based on the goal of avoiding preprocessor conflicts. CSS is a much more fundamental thing that require carefully weighed decisions reasonable and usable in the long term. Preprocessors can be changed at any time, **CSS cannot at all**. [@upsuper](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-221835505): > I'd prefer `@if`... not very strongly, though. > > I agree with @Marat-Tanalin that we should not pick a weird syntax just to avoid conflicting with a preprocessor, and preprocessors can always work around that easily, either via a breaking change stated in the release note or introducing a new keyword. > > I can imagine that if we choose `@when` and `@else-when`, more developers would tend to critize that CSSWG is making their life harder via adding some syntax different than what they are familiar with, rather than appreciating the work of avoiding the imaginary breakage. > > I think the criteria is, is there more web developers use SASS's `@if` than those who do not use SASS's `@if` (or do not use SASS at all) but familiar with the general if-else structure? What's the percentage? [@bradkemper](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-302982454): > I strongly prefer @if, @else, and @else-if. It would be clear and obvious for most authors, and SASS could easily adapt. [@leaverou](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-919879061): > I'd like to express my **strong** agreement with @upsuper, @Marat-Tanalin and @bradkemper above in favor of `@if` over `@when`. > > 1. [Consistency](https://w3ctag.github.io/design-principles/#consistency) with every other language authors may have used > 2. As has been repeatedly mentioned, we should not be designing CSS, a language that needs to last decades and for which the burden of changes is incredibly high, based on conflicts with a preprocessor that _happens_ to be in use today (and is already giving way to others, e.g. PostCSS). Preprocessors can adapt far more easily than CSS, and any third-party project ultimately has far fewer users than CSS. Many solutions for Sass have been suggested in this very thread. > 3. Preprocessors are not executed on every page load, so it's far easier for Sass authors to migrate to a new syntax at their own time. This is not like the issue TC39 faced with `array.contains()` at all. > > Note: `@if` _is_ used quite heavily: [about 63% of Sass stylesheets use it](https://almanac.httparchive.org/en/2020/css#fig-72). But even if it was used in 100% of them we should not design CSS around Sass. [@svgeesus](https://github.com/w3c/csswg-drafts/issues/112#issuecomment-919946127): > Adding my agreement to call this `@if` not `@when`. > > I recall that the Sass maintainers have explicitly stated that CSS should **not** avoid a good syntax just because Sass uses it; they are very willing to change so that CSS can get better. Please view or discuss this issue at https://github.com/w3c/csswg-drafts/issues/6614 using your GitHub account -- Sent via github-notify-ml as configured in https://github.com/w3c/github-notify-ml-config
Received on Wednesday, 15 September 2021 17:28:28 UTC