Use the data-force attribute, Luke
Its not widley known that you can arbitrarily set data attributes in your elements. Here is a little tip that might help with some slick widget templating.
The format is simply data-*:
<div id="thing" data-widget='{"status":"awesome","code":"thumbsup"}'>
So what?
Now you can do this:
var widgetData = $("#thing").data("widget");
if( widgetData.status === "awesome" )
haveAParty();
- beware of the quotes " vs ' will mess things up!
Written by Peter Peterson
Related protips
6 Responses
data:image/s3,"s3://crabby-images/8455b/8455b929a2aab05bfd6306a399cba34ab4303af7" alt=""
I didn't realize the jQuery .data() function automatically decodes JSON data. What does it do if non JSON data is used as the attribute (which is perfectly acceptable)?
data:image/s3,"s3://crabby-images/41b79/41b7966bab01c8ca859046afa6bc3d98228424ae" alt=""
It just treats it as text. I imagine one could hook up .data()'s internals to use another decoder, which might be neat in some cases (maybe convert space/comma-delimited list into an array?).
data:image/s3,"s3://crabby-images/88f1c/88f1c5b09def24e64d5b9691e5a628152231c5aa" alt=""
Note that $(el).data("key", "value") doesn't add a data-attribute to the HTML, it just modifies an internal jQuery array. If you're planning on modifying things then using the HTML elsewhere, you'll need $(el).attr("data-key", "value").
data:image/s3,"s3://crabby-images/16d0f/16d0fff0d3072e0459593f64c8f49e264011a093" alt=""
@reactiveraven but it modify the data API so you can make a .data('key') after this and get the good value. Even in another script ;)
Wow!!! ... I didn't know I can create mine just like that.
data:image/s3,"s3://crabby-images/7284e/7284e63a5e4363f7bac90e51c8f487c543ddeadb" alt=""
Beware jQuery.data also can treat content as integer so if your really need a number higher than a 32 bits integer, it will be truncated.
jQuery.attr('data-blabla') is safer if you need to deal with data integrity.