Settings

Theme

Universal.css

github.com

289 points by jchampem 10 years ago · 117 comments

Reader

mrgreenfur 10 years ago

Poes law meets css: "Poe's law is an Internet adage which states that, without a clear indicator of the author's intent, parodies of extreme views will be mistaken by some readers or viewers for sincere expressions of the parodied views.[1][2][3] " https://en.wikipedia.org/wiki/Poe%27s_law

hashkb 10 years ago

This is amazing. I quit a job at a company that did many stupid things, one of which was insist that their home rolled CSS framework did not suck. Said framework was, in all seriousness, exactly this but with shortened, cryptic names. Nightmare.

  • dclowd9901 10 years ago

    Ideally, in SMACSS, you could classify all components into their composable parts: a grid width, a title style, a button with a primary style, a button with a secondary style, standard body text, emphasized body text, etc.

    But most of the time, designers don't know how to stick with a standardized padding and margin, so I find that without exception, an org requires me to develop "cryptic" representations of margin and padding, such as mr1 (margin right to 1 degree, or 5 px) or pl2 (padding left to 2 degrees, or 10px).

    I've also rolled entirely new features without writing a single line of CSS. This is a way to mitigate CSS bloat. I take it you've never actually tried to deal with the problem of CSS bloat, or you'd find either 1) you'd have to hold a gun to designers' heads or 2) do exactly what I just showed you.

    • vkjv 10 years ago

      I've had a very different experience with designers. I would say that ~95% of them something is a couple pixels off, a slightly different font size, or a shade off in color, it was a mistake.

      Usually a quick follow-up question will reveal the mistake and the designer is happy to make the correction.

      This has been my best weapon against CSS bloat.

    • notJim 10 years ago

      This is weird, because designers I've worked with hate CSS bloat even more than I do, and love things like consistent spacing and typography. The movement towards styleguides has been one of the biggest things happening in design in the last year or so, which is exactly what you're talking about with not writing CSS.

      • blwsk 10 years ago

        To add to this, the addition of a style guide is helpful on two fronts.

        * Components and patterns are standardized, allowing for less process in design reviews and quicker iteration

        * Engineers can create component libraries that mirror style guide elements and turn frontend work into something a little closer to 'lego' building

  • bherms 10 years ago

    Haha... :)

roddux 10 years ago

>Bootstrap V4 recently introduced spacing utility classes like m-t-1 (which translates to margin-top: 1rem!important), and we thought we'd expand this idea to more classes.

Which is worse; when it's done as satire, or seriously?

steego 10 years ago

Absolutely brilliant! Because of its universal nature and compositional design, one only has to download this CSS page once from the primary CDN and it can be used for everything everywhere. One could even argue this should be a standard browser component.

nachtigall 10 years ago

You'd think this is a joke, but have a look at this comment at https://hacks.mozilla.org/2016/05/css-coding-techniques/comm...

> Now that we’re writing almost all of our html in modular fashion, I have found mix-n-matching pre-defined css classes works the best. i.e. class=”inline-block bg-bbb text-333 padding-5-15″

aplummer 10 years ago

This is great. Something similar was on hacker news without the "of course this is a joke" qualifier:

https://news.ycombinator.com/item?id=11001820

ojii 10 years ago

At under 5MB, it's quite lightweight compared to other modern tools too, nice!

yAnonymous 10 years ago

They're making fun of Bootstrap, but having classes that allow you to define margins and padding quickly by adding a class is actually really helpful. Of course that shouldn't be expanded to every possible property.

  • djsumdog 10 years ago

    You can use Foundation + sass processor and not need any of that garbage. My website just has nav, main, sidebar, etc. I define what I want into foundation to be mapped to them and the preprocessor creates my minified CSS.

    http://penguindreams.org/blog/jekyll-3-and-foundation-6/

    Adding "row-xx" or whatever to your HTML elements is basically going back to the garbage that was in table based html layouts.

    • silverbax88 10 years ago

      I really don't know how to take your comment...are you suggesting that precompiling and overriding the functionality native to CSS is easier than just using a handful of classnames?

      • mieko 10 years ago

        They're suggesting that Bootstrap-like classes that name and reference a specific visual rendering (e.g., col-md-hidden) are no better than the old ROWSPAN/COLSPAN mess. They've just moved from HTML attributes to being packed into the class attribute.

        Then again, semantic markup was a huge pain in the ass before tools like SASS. Now you can actually name and categorize elements semantically in the markup, then decide what that actually means in the pre-processed CSS.

        Edit: And it's true: Having recently gone through even a simple bootstrap-to-bootstrap redesign, we pretty much had to comb through every view and remove/replace non-semantic CSS classes. With SASS mixins and semantic markup, it'd have been a CSS-only change.

smhenderson 10 years ago

Here's my favorite part of the presentation:

View Raw

(Sorry about that, but we can’t show files that are this big right now.)

chrismonsanto 10 years ago

The effect of the joke is lessened when it is labeled as a joke, doubly so when every comment here copypastes the line saying it's a joke.

See also the latest reprinting of "A Modest Proposal," which kindly has "SATIRE -- DO NOT BELIEVE" in large caps on the front and back covers.

  • HCIdivision17 10 years ago

    To be fair, the top comment here calls out Poe's Law. You can see this best by how "A Modest Proposal" was recieved: the anonymous author was villified and many powerful people were outraged. People were repulsed and offended and everything'd else by it.

    One of my favorite Asimov quotes is "It pays to be obvious, especially if you have a reputation for subtlety." It's a damn shame that it's helpful to put blaring giant signs that say SATIRE on it and ruin the joke a bit, but there's just a ton of people out there who just never really got up to speed on detecting it. Many - possibly most! - people really don't look that deeply into things and tend to take stuff at face value (or don't know that there is a deeper meaning to spot), no matter how outlandish.

    All that as a mea culpa, as I read the OP's README and thought, "man, that seems like a bit of a mess... under what circumstances would you need to do that?" The answer is NO DO NOT DO THIS but I, lacking experience, kinda didn't get that right off the bat.

    • chrismonsanto 10 years ago

      > To be fair, the top comment here calls out Poe's Law.

      The top comment when I posted was a copypaste of the joke disclaimer. And the top reply to the top comment at the time of this posting is a copypaste of the joke disclaimer.

      > Many - possibly most! - people really don't look that deeply into things and tend to take stuff at face value (or don't know that there is a deeper meaning to spot), no matter how outlandish.

      If someone can't figure out why generating a CSS class for every (property, value) combination is funny, then I don't think an explanation will help. Maybe it will give those readers an A-ha! moment and a valuable life lesson, but it won't be funny for them.

      > All that as a mea culpa, as I read the OP's README and thought, "man, that seems like a bit of a mess... under what circumstances would you need to do that?"

      If you got rused then that's great. The joke did what it was supposed to do. What sucks is that people who instinctively click the comments first won't get that experience, because some killjoy had to post "IT'S A JOKE DON'T FALL FOR THIS."

usmanshaikh06 10 years ago

Is this a joke?

Of course it's a joke. Use semantic CSS class names.

YngwieMalware 10 years ago

I was almost offended until I realized it was too absurd to be real. Really happy this is a joke, holy crap.

ryannevius 10 years ago

This reminds me of Tachyons[1], except Tachyons (supposedly) isn't satire.

[1] http://tachyons.io/

  • bshimmin 10 years ago

    I think I'd have to assume anyone using that on a project I was paying them for really was trying to be funny. I mean, really, take a look at this: https://github.com/tachyons-css/tachyons-visibility

    • cel1ne 10 years ago

      I used and am using this in production. So are others. It works really really well.

      Here's the rational: http://mrmrs.io/writing/2016/03/24/scalable-css/

      • akavi 10 years ago

        These are valid issues, but one that has a better, actually scalable solution: CSS preprocessors.

        You can name your magic numbers/RGB values. You can move your shared behaviour into mixins. You can stop using float for god's sake - it's 2016, we have flexbox now (OK, so that's not related to preprocessors, but it's still true).

        Sure, if it's a quick hack or something you're throwing together for personal reasons, use whatever mixture of inline-styles, "visually semantic" classes, and table layout goes fastest for you. But if the point is "scalability" (In the sense of size of team working together), then this halfway point between semantic classes and inline styles is definitely not the right way to achieve it.

        • spdustin 10 years ago

          If you want a website that works on enterprise desktops, you aren't using flexbox - you're using floats.

          • akavi 10 years ago

            Is that still true? I recently joined a company whose primary audience is education, and our numbers say that less than 1% of our customers use browsers that don't support flexbox.

            Are public middle schools farther along the tech curve than "enterprise"?

            (Legitimately curious. It'd be pretty funny if so.)

        • cel1ne 10 years ago

          I used css-preprocessors (LESS, SASS and various postcss-configurations), but now I'm glad to not have another layer of imports and logic in CSS. Especially in react-driven pages.

          I wonder, though, if there could be some workflow where you write and edit with tachyons, (babel-) analyze the code, find commonly used combination and prompt to name them.

          EDIT: I also usually work with only two or three people, I guess it's different if there are 20 working on the css.

          But especially in teams: don't you consider it extremely valuable that one can change the style of exactly one part somewhere in the page without affecting anything else?

      • ryannevius 10 years ago

        In all seriousness, what advantages do you see over writing inline styles?

        • cel1ne 10 years ago

          Tachyons is based on mathematical scales: http://tachyons.io/docs/layout/spacing/

          Practical example: I have a form with a header. I look at it and think "there needs to be more space below the header". So I change

            className="mt0"
          to

            className="mt1"
          
          It hot-reloads etc. It took me exactly two keystrokes to change this and I know that the spacing is consistent with all the other spacing in my app.
          • ryannevius 10 years ago

            But how is that any more efficient than changing:

                style="margin-top: 1rem;"
            
            to

                style="margin-top: 2rem;"
            
            It's also two keystrokes, and is mathematically determined...
            • cel1ne 10 years ago

              1. way less clutter and repeating, my whole style is in one line per tag.

              2. the scale also has fractional rem values.

              I'd rather change "f5" to "f6" for a smaller font than: "fontSize: 1rem" to "fontSize: 0.875rem".

              3. the author of tachyons clearly understand design. If he improves his stylesheet, I benefit.

              4. Apparently inline-styles are slower [0], but I don't count that since everything could be extracted.

              [0] http://ctheu.com/2015/08/17/react-inline-styles-vs-css-stupi...

              5. I thoroughly enjoy using it. :)

          • bshimmin 10 years ago

            Perhaps I'm just a fuddy-duddy, but I rather like MDN's description of what classes used to be for: https://developer.mozilla.org/en-US/docs/Web/HTML/Global_att... (The second paragraph.)

        • crucialfelix 10 years ago

          It is much faster to type and maintain, easier to read, smaller document size and faster for the browser to parse.

          • ryannevius 10 years ago

            Is there a benchmark you can point me to for "faster for the browser to parse"?

            • crucialfelix 10 years ago

              sure, I searched for tests just before I posted my comment.

              http://ctheu.com/2015/08/17/react-inline-styles-vs-css-stupi...

              I use react inline styles in some situations where it's appropriate. on large tables or SVG (eg. with zillions of styled circles) there will be issues.

              if you are sending HTML from a server with inline-styles then you will have much bigger problems with bandwidth.

              This is where tachyon and basscss can provide a clean way for the day to day simple styling tasks like "needs more padding here" "make that title bigger there" without writing up stylesheets with repetitive margin, float, etc. for every single view in your app or every page on your website.

        • ranyefet 10 years ago

          Better caching, smaller HTML size and the ability to use inline styles if you do need to override something

          • ryannevius 10 years ago

            Are `class` attributes cached more efficiently than `style` attributes for some reason?

            • Touche 10 years ago

              I assume he/she means that CSS is cached as an http resource and can be reused in different pages, whereas style attributes are only cached as part of the page; ie using them adds page weight.

      • christophilus 10 years ago

        I've been looking at this recently. I'd really love to hear more about real-world experience using Tachyons. We're suffering from serious bloat (500KB CSS) on an old project, and are trying to figure out how best to manage CSS so it doesn't bloat over time (at least not as much).

  • odonnellryan 10 years ago

    Reminds me of React! ;)

    Not trolling, I think React is a fine framework.

blowski 10 years ago

Funny, but before we all get on our high horses:

1. Bootstrap is partly for prototypes and quick interfaces where front end best practices don't matter.

2. If you're using a preprocessor, you can include Bootstrap's classes and rename/combine them to something semantic.

3. Something can be a good idea when done in small quantities, and a terrible idea when taken to extremes.

sunnyshahmca 10 years ago

I know it is a joke. I have been a contributor to the Webkit project and these kind of jokes really scares me to death.

binthere 10 years ago

People who don't understand the concept of atomic CSS usually joke about it, but has no idea about the benefits. The new Twitter mobile site is fast as hell and use this concept. Semantic class names makes no sense when you think about it.

megalodon 10 years ago

Delightful, cringe-entailing humour; this definitely made my day.

kevinyun 10 years ago

If you don't read the docs fully, everything looks really official with 314 stars social credibility too

lanestp 10 years ago

It's sad that my first reaction was "Looks like bootstrap." I would like a few more colors. Maybe you could add pantone support, that would make this super useful esp. for mobile!

Randgalt 10 years ago

The real joke is how screwed up client side programming is. Here's a library that's an insider/hipster joke but it's only obviously a joke to hipster/insiders.

  • hawleyal 10 years ago

    Blah blah blah doesn't like JavaScript

    • Randgalt 10 years ago

      Javascript is fine. It's the fact that the ecosystem changes every few months and devs post things like "look how ridiculous this old way of doing things is" when the old way was just last year (or 6 months ago) when _it_ was the new hotness.

leray_J 10 years ago

I'm getting scared to see that on front page, I'm the kind of guy which could have enough luck to randomly fall into a project where someone used it for real.

  • at-fates-hands 10 years ago

    "Dude, I just found the coolest CSS framework, take a look. This is going to solve ALL of our problems!"

    I've had this happen a few times with other developers I thought were pretty sharp. The best example is when someone found Dogescript (https://dogescript.com/) and was convinced it was the next big thing. The best part was I didn't have the heart to tell him the truth.

    • leray_J 10 years ago

      Are you kidding me?!

      How can someone take Dogescript seriously?! That is so retarded, even a guy witch is not into programmation and hang out on 9gag sometimes can tell it's a troll!:O

return0 10 years ago

This is awesome. I no longer need to type the dreaded ":" , which requires the most awkward finger combination . My ulnar nerve will be so happy.

jjar 10 years ago

I was about to flip the table before reading the last faq. Good one.

thierryk 10 years ago

I think we should judge a technique in regard to the problems it solves and the ones it creates, not in regard to our understanding of the said technique.

No, it is not the same as using "inline styles" (just think about it). Yes, it reduces CSS scope and bloat in styles sheets. Yes, it breaks the Separation of Concern principle. No, it does not create bloat in the markup. Yes, it forces you to style via markup rather than via a style sheet, etc.

Like with any other technique, choosing to use "Atomic CSS" in a project should be considered in relation to the problems authors have to solve. CSS is a complex matter, there is no one size-fit-all solution and there are not that many solutions either so I think we should think twice before disregarding a tool, any tool.

PS: Yes, I know universal.css is a joke but it is mocking a real/serious approach to big CSS problems.

Loque 10 years ago

I am really glad someone has put this together - I was enjoying Harry Roberts talk at RenderConf until he dropped this in our faces: http://csswizardry.com/2016/05/the-importance-of-important/

Utility classes I dislike (mixins plx) and the idea of using important with them is not a design decision I would want to pick up.

I guess my bigger problem is that Harry sells himself as an expert, stands up on stage telling people this is how they should be doing things... and here I am, no book, no stage and my specificity level gets trumped by Harry amongst certain members of my team (despite my years of qualified awesomeness across large scale, popular, public domain sites)

Thought I'd just share that with you :`P

  • SquareWheel 10 years ago

    I read that post earlier and it seemed fine. If you add a .bold class to an element, why would you want it to sometimes not be bold?

    Utility classes don't belong everywhere but I think it's going a bit far to discredit the man for proposing this. His work on ITCSS in particular shows he's well versed in the language. I find this system far more sane than other proposals.

    • Loque 10 years ago

      Why bother with class 'bold' when you could use inline styles? (I jest)

      I come from an older thinking that your HTML should not have any classes that imply visual style, and that classes/id's should be semantic to the content and structure of the HTML.

      CSSZen garden is a good example of this.

      Nowadays I personally love semantic markup, stylistic mixins, and a CSS file linking the two together following BEM patterns.

      I think legitimate times when this falls apart, is when I watch the designers I work with now, work in HTML & CSS - they need to quickly move things around, so doing this all from markup gives them a big speed increase, up until a point that is. We get involved now early after initial client direction sign-off to make their markup and CSS more robust before they carry on like a pig in poo.

    • mieko 10 years ago

      > If you add a .bold class to an element, why would you want it to sometimes not be bold?

      The problem is having a class called .bold, and then baking it into your HTML. I feel like many people arguing this have never undertaken a full-scale visual redesign on a large site. The designer comes in, and all the sudden everything marked .bold ends up meaning "lightweight italicized text". This presentational/semantic cycle repeats every 6 years or so, but I'm not sure where it's heading.

yuvalkarmi 10 years ago

this is wonderful! finally, a clear, succinct way of writing CSS. This is what I've been waiting for since I wrote my first <font /> tags when I was eight.

kalkin 10 years ago

I pretty much completely disagree with the implicit critique here. The codebase I work on now has largely transitioned from "semantic" CSS (classnames based on feature) to CSS with classnames that describe what they do, visually, and the latter has made writing frontend code dramatically more straightforward - it's gone from something I dread and try to pass off to a specialist to something I can do easily. A night-and-day improvement.

I mean, nobody actually advocates translating every single possible style attribute into its own CSS class. But what's wrong with padding and margin utility classes that use a consistent set of widths? Is doing calculations on "1x" and "2x" when you want elements to line up really worse than doing calculations on pixel or em values in your CSS just because it's "unsemantic"?

Let's take the examples from the "maintainable CSS" book that's linked:

  <!-- bad [sic] -->
  <div class="red pull-left">
  <div class="grid row">
  <div class="col-xs-4">

  <!-- good [sic] -->
  <div class="header">
  <div class="basket">
  <div class="product">
  <div class="searchResults">
Ask yourself, in which case can you read the code and tell roughly how it's going to render? In which case do you think you'll be able to re-use the classes on other pages? If you wanted to make another, visually consistent page that shows, say, seller search results instead of product ones, in which case do you think you'll be able to figure out which styles need to change more quickly?

Here's the backend equivalent:

  # "bad"
  def cheapest_products_with_min_rating(rating)
    products.
      select { |p| p.rating >= rating }.
      sort_by { |p| p.price }.
      first(10)
  end

  # "good"
  def products_for_category_landing_page(rating)
    allowed = []
    for p in products
      if p.rating >= rating
        allowed << p
      end
    end

    # pretend I've implemented quicksort here
  
    result = []
    for p in sorted
      break if result.length >= 10
      result << p
    end

    result
  end
Ugh, that first example - using all these "unsemantic" components like "sort" and "select"! How do I know when I look at the implementation of any of them, or the function itself, what the intent is? What business problem is being solved?

The second example - so nice and "semantic". If we want to change what products show up on the category landing page, it will be easy!

...

In real life, nobody writes backend code like that. Why should we tolerate it in the frontend?

  • kowdermeister 10 years ago

    I'm with you. I'm not sure why semantic purists need to spread the idea that utility classes are bad. 1 class name for every property is stupid of course, but layout classes (yes, used with semantic HTML elements) are a great help if used with discipline.

    After all, who are we writing code for? - The end user? He can't care less about the class names. - Search engines? They can surely identify relevant content. Semantic classes help, but they don't rule out utilities. - Ourselves? I can read utility/semantic classes well especially that I've written. Also not a case against utilities.

rudedogg 10 years ago

I've been working on an app that relies on parsing CSS styles for like 6 months - full time. This almost gave me a heart attack until I realized it was a joke.

Kmaschta 10 years ago

See https://news.ycombinator.com/item?id=11737510

cfvergara 10 years ago

Seriously though. What's bad about using, say, tachyons and composing several of its pieces inside more meaningful labels like "sidebar" or "header" or whatever? It's simpler to grasp, and it WILL wind up as one dictionary per node anyway

mat_jack1 10 years ago

It's really funny because I'm working on a real project which uses a CSS which is really like universal.css, and we are thinking of going responsive. Luckily at least this is a joke.

I sympathize with the other commenters with my same problem.

mendelk 10 years ago

I know this is meant as a joke, but having used BassCSS[0] in a production webapp, I believe it really is a valid approach to CSS.

To each their own, I guess.

[0] http://www.basscss.com/

chrispie 10 years ago

go on and just waste more time on this by reading the comments

drivingmenuts 10 years ago

Can someone kindly explain how I'm supposed to feel about this? I'm on mobile ATM and my feelings are somewhat restrained by available processing power.

nkjoep 10 years ago

Does this compile with vanillajs?

babby 10 years ago

I've done this before. The performance on IE, firefox, safari and mobile is complete shit yet suprisingly good in Chrome.

syzygykr 10 years ago

cornflowerblue was a nice touch.

foota 10 years ago

(Sorry about that, but we can’t show files that are this big right now.)

Uh oh

typedef_struct 10 years ago

For about 15 seconds I was horrified. Time to go to bed.

cloudjacker 10 years ago

> Of course it's a joke.

whew, had me going there

surunzi 10 years ago

Obviously, it's just a joke.

bingeboy 10 years ago

Sign me up.

mobiuscog 10 years ago

These frameworks get everywhere.

dikiaap 10 years ago

Cool

fortytw2 10 years ago

> Where is the documentation? > You don't need documentation.

What constitutes self-describing code is wildly different depending on the person. I mean, really?

EDIT: I definitely missed that this is a joke :'(

jstoja 10 years ago

In the end, why not directly have the JS reading the class and generating only what's needed? That would be very cool! I'm still having some doubts about the maintainability (duplication, isolation...) of such styling btw...

fiatjaf 10 years ago

People really waste their time on these jokes.

I have a lot of ideas for small side projects that could be good (or probably not, but at least I wanna try them seriously) and can't get time to implement them, and people who have this time waste it writing universal.css.

smegel 10 years ago

So I have to choose between a several Meg download vs using JavaScript to render styles?

No thanks.

Honestly I thought bootstrap was the only css I would ever need, and this hasn't changed my mind.

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection