Hacker Newsnew | past | comments | ask | show | jobs | submit | Calvein's commentslogin

They should really be in data-attributes instead of classes imo. And not having issues on Github is quite a weird, especially when the first rule for contributing is: > Create an issue


Why on earth would someone want to apply CSS via data attributes instead of classes? That's the kind of statement you need to justify.


The filters are a collection of the same type of things. Therefore its more akin to filterAttr = filterEnumVal[autumn,auburn,sunnydale,cheezit,etc..]

Instead of polluting the CSS namespace, it's much more apt to use a data-instafilter="[val]" property.


Well goldenkey answered perfectly for me here.


Structural purposes.

Personally, I hate moving/changing/adding classes with Javascript. classList is hacky. Stuff like this is exactly what data-attributes are for. [0]

  img.dataset.filter // "instagram filter type"
The CSS would need slight changes, accordingly:

  img[data-filter="filter_type"] { /* styles */ }
[0] https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Usin...


Why does everyone here seem to be assuming the primary use-case is some kind of interactive on/off filter?

Surely the common setting for this to be applied is in a web page where the author/photographer/designer has already selected a fixed filter and the visitor is just looking at it applied. A UI allowing someone to toggle or select filters on an image is the exceptional case here.


There are better ways to accomplish this if you just want a fixed filter... such as displaying the image with the filter already applied instead of relying on user's (non-IE) browser to do it. Unless you plan to not support IE users at all, which is a rather big "don't do this" for front-end dev.

So a UI to select filters to apply in FF/Chrome as progressive enhancement seems to be the best use case I can see for this, if I can be frank.


"Better" from an infrastructural perspective maybe, for performance reasons, etc. but for many people quickly dropping in a bit of frontend magic is very often opted for in practice over more performant server-side setups.

As for not supporting IE users at all, it's a filter - you don't lose image display.


Hm, this is an interesting case where stylesheet design principles and application logic aren't so loosely coupled.

The data attributes almost seem to be a way to invoke CSS styles as functions themselves.


The main difference is that using classes, is misusing them. Because enum values as classes pollutes the namespace.

Enum values should map to attribute values. It makes logical sense. Attribute values don't go into a namespace. They just exist as things to query by.

It is possible many CSS engines optimize this fact. By not caching attribute values until there is a selector that uses them. Classes on the other hand are inherently saying 'I will query by this at a later time - I give no hints as to whether it is mutually exclusive with other class values. I merely have a list of class values which apply.'


Interesting, thanks for pointing this out.

I am still unclear, though, how you draw the line, in general, between things that belong in dataset and things that belong in standard classes?


goldenkey explained this well in their response.

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


I read that but it still isn't clear to me.

What is the namespace in question that we're polluting?

Where do you draw the line? Eg, take something a simple as creating striped table rows. Is something like 'class="oddRow"' wrong, because technically that's an enum value -- the rows can be "odd" or "even". Should we instead write 'data-rowtype="odd"'?

Basically, I need to see some more examples to understand the distinction better.


I've never understood separating by odd/even. Typically the people who do this only want to add styles to "alternate" rows. So I would use 'class="alternate"'.

>Basically, I need to see some more examples to understand the distinction better.

Personally I do it only for organizational purposes more than anything else. The "actual use cases" are a bit contrived if I'm being honest, at least for this example.

Let's say you have 5 photos on a page, each with different filters applied on different locations of the page. You want to allow users to normalize the page by selecting a single filter to apply to every photo.

I'm not a JS expert - but the first seems a lot easier to manipulate multiple images at once. A single check of img.dataset.filter instead of checking against an entire array of classes. (If there is a simpler way of checking the class example, I'm all ears.)

  <img src="/" data-filter="oldschool" class="medium"> //change to greyscale
  <img src="/" data-filter="fuchsia" class="large"> //change to greyscale
  <img src="/" class="large"> //not to be changed
  <img src="/" data-filter="1970" class="small"> //change to greyscale


  <img src="/" class="medium oldschool"> //change to greyscale
  <img src="/" class="large fuchsia"> //change to greyscale
  <img src="/" class="small"> //not to be changed
  <img src="/" class="small 1970"> //change to greyscale


If you're saying your sole reason for doing this is to ease your javascript selection, I think that's a poor reason. If you have a serious dynamic javascript page of any complexity, you have should have a pure js model and your view should be updating off that, using react, mithril, or your own vanilla update function. Now, not everyone would agree with that, and there may be use cases where it's overkill, but in that case I still don't buy the argument, as you can just write a short helper function that makes things just as easy as selecting with dataset.

I don't think a fear of javascript should be driving decisions about markup. You should write your markup in the clearest, most semantic way possible, and let what are ultimately trivial js problems take care of themselves.


>You should write your markup in the clearest, most semantic way possible

Semantically is exactly why data-* should be used instead of classes. But semantics often include a bit of extra work (adding a data-filter attribute instead of just throwing an extra class in the mix) and so people throw them aside all too often.

>I still don't buy the argument, as you can just write a short helper function that makes things just as easy as selecting with dataset.

So to avoid doing things the proper way you would write a helper function to get around a problem?

The CSS can be written both ways (you can use [data-filter="..."] as a selector). The difference is between using data-* or adding a class. The difference between the two comes down to semantics and in some niche scenarios the ability to easily change the value.


All I'm saying is that so far the only tangible reason you've given is that it makes doing javascript selections easier. I'm not saying using data-* liberally is a bad idea, I'm saying that is a bad reason for it. You've also mentioned semantics, which would be a good reason, but I'm still unlcear what the semantic argument is. To use the stripe row example, 'class="alternateRow"' seems just as semantic as 'data-rowtype="alternate"'. If I'm still missing something, I'd like to learn more. Again, additional examples would help. Discussing this kind of thing in the abstract is a recipe for miscommunication.


> classList is hacky

How so? I don't think that it's in anyway hackier than its sister dataset.


I don't understand that comment either, but it might be the lack of classList support in earlier IE versions without a polyfill.


I hate moving/changing/adding classes with Javascript. classList is hacky.

...in what way?


I think Una turned issues off on her repos...she's getting issue spam:

https://twitter.com/Una/status/659128221292605440


Woah. I wonder if you can notify github about such behavior and if something would be done about that. Because that's really not pretty.


Apparently she (and all those watching the project) got spammed so she had to shut down issues - https://twitter.com/Una/status/659128221292605440


Any indication if Apple is going to support pointer events[1] now since there is a stylus ?

[1]: http://caniuse.com/#feat=pointer


What about the new Razer blade ? I'm in the same situation as the OP but my company is keen to get me the laptop I want (my Zenbook was great but its 4GB or unupgradable RAM is a bummer) so I don't really care about the price.


On Linux (and WIndows I presume) it's with the alt key.


You can write this without any problem:

  var x = function() {
    // something
  }

  // avoid polluting global scope:
  !function() {
    // Some initialization.
  }()


So now you've gone from a semicolon, which has the sole purpose of separating statements; to a bang, which doesn't make any sense in this context unless you know that it's replacing a semicolon.

Better or worse?


You could use anything which separates statements or ensures the function is treated as an expression. Two examples which are more in keeping with the intended use of the operators in question:

  ;function() {
    // Some initialization.
  }()

  void function() {
    // Some initialization.
  }()


So now we've gone a) from semicolon consistently after statements, to having to remember where to prefix with semicolons, or b) from one character to four.

Why aren't we just using the semicolon as it is required in any other (C-based) language?


JS's syntax is influenced by C via its pretensions of being somehow related to Java, but I think it's a stretch to call it a "C-based language".


Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: