jQuery plugin to associate label “for” attribute with form controls that have dynamic id’s

For whatever reason, you can’t associate your labels with your form controls implicitly by wrapping both the label text and the control in a <label> element:

<label>
  Email address: <input type="email" name="email" value="" placeholder="you@example.com"/>
</label>

You’ve had to explicitly state the form control you want the label to be associated with:

<label for="email">Email address:</label>
<input id="email" type="email" name="email" value="" placeholder="you@example.com"/>

…but your framework has other ideas, it decides to commandeer your precious “id” attribute and change it from a simple and beautiful “email” into a junky “dnn_ctr1163_RegistrationForm_email”. *cough* DotNetNuke *cough*, but also *cough* Wicket *cough* and probably a whole load of others.

The problem is now that your label is no longer associated with your form control, and there isn’t a simple fix, like, for example, change the for attribute to read “dnn_ctr1163_RegistrationForm_email”, because the numbers in the id change each time you refresh the page. The ID is dynamic, and you are receiving accessibility black stars.

So, luckily I noticed that often the id will change, but the framework will leave your originally intended id somewhere in there. I’ve written a jQuery plugin to look at label for attributes and try to find the form control you intended to associate it with before your server side framework so rudely changed it.

How to use

  1. Download the plugin and add it to your page
  2. Select the labels you want to re-associate and call the function eg. $(‘label’).fuzzyFor();

TODO

The plugin finds matches by looking for input, select and textarea elements in the document and checking to see if the for attribute in your label element appears in the id attribute of the form control. At the moment if more than one match is found, it just uses the first (which is probably good enough for most). However, it should probably do something a bit more clever and use the form control that is closest to the label (I’m reasoning that you normally put your label’s close to your controls).

8,322 thoughts on “jQuery plugin to associate label “for” attribute with form controls that have dynamic id’s

  1. That is very attention-grabbing You are an overly skilled blogger. Ive joined your feed and look ahead to seeking more of your excellent post. Additionally I have shared your web site in my social networks librabet accedi

  2. canadian pharmacy king: CivicMeds – cheapest pharmacy for prescriptions without insurance

  3. prescription free canadian pharmacy: CivicMeds – canada drugs online reviews

  4. Whats up are using WordPress for your blog platform? Im new to the blog world but Im trying to get started and create my own. Do you require any html coding knowledge to make your own blog? Any help would be greatly appreciated beste online casino ohne oasis

  5. walgreens online pharmacy CivicMeds www pharmacyonline

  6. Superb what a webpage it is This blog provides valuable facts to us keep it up. buy xanax without prescrition sexual porn pills

  7. Wow incredible blog layout How long have you been blogging for? you made blogging look easy. The overall look of your web site is wonderful as well as the content Betify

  8. Generic Cialis without a doctor prescription: VeritasCare – Cialis without a doctor prescription

  9. Sildenafil Citrate Tablets 100mg: best price for viagra 100mg – Viagra Tablet price

  10. safe canadian pharmacy CivicMeds best online pharmacy reddit

  11. best mail order pharmacy canada: canadianpharmacyworld com – canadapharmacyonline

  12. fastpay casino uk, best online casino australia no deposit bonus
    and australia crowne plaza to crown casino [Bettie] online real money, or 2021 no deposit bonus codes uk

  13. canada drugs coupon code: best mail order pharmacy canada – canada pharmacy online

  14. Cheapest Sildenafil online Sildenafil Citrate Tablets 100mg Viagra tablet online

  15. Viagra without a doctor prescription Canada: sildenafil online – CoreBlue Health

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>