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,282 thoughts on “jQuery plugin to associate label “for” attribute with form controls that have dynamic id’s

  1. проект планировки железнодорожного пути Он содержит информацию о допустимых нагрузках геометрии и мероприятиях по обеспечению безопасности.

  2. AccessBridge Pharmacy: AccessBridge Pharmacy – AccessBridge Pharmacy

  3. no prescription pharmacy paypal: indian pharmacies safe – online pharmacy without prescription

  4. new pharmacy online FormuLine Pharmacy worldwide pharmacy

  5. SteadyMeds pharmacy: onlinecanadianpharmacy – SteadyMeds

  6. online drugs order: online pharmacy india – best online pharmacy

  7. My spouse and I absolutely love your blog and find almost all of your posts to be what precisely Im looking for. Does one offer guest writers to write content available for you? I wouldnt mind writing a post or elaborating on most of the subjects you write about here. Again awesome website https://share.google/1k6M9JrDImxkdiWGe

  8. Thank you for any other informative website. Where else could I get that kind of info written in such a perfect approach? Ive a mission that Im simply now running on and I have been at the look out for such info. https://share.google/RbpWIniCOLJeIqdSC

  9. youre in point of fact a good webmaster. The site loading pace is amazing. It sort of feels that you are doing any unique trick. Furthermore The contents are masterpiece. you have done a wonderful job in this matter https://share.google/SwxiNgQlQHgU61C3r

  10. Woah! I’m really loving the template/theme of
    this website. It’s simple, yet effective. A lot of
    times it’s hard to get that “perfect balance” between superb usability gambling and internet use disorder (Merrill) visual appearance.
    I must say you’ve done a superb job with this. Additionally, the blog loads very
    quick for me on Internet explorer. Superb Blog!

  11. legal online pharmacies in the us: india pharmacy – shop medicine online

  12. SteadyMeds pharmacy: SteadyMeds pharmacy – SteadyMeds pharmacy

  13. best online pharmacy buy medicines online in india best online pharmacy no prescription

  14. pharmacy websites: FormuLine Pharmacy – shop medicine online

  15. best canadian pharmacy: SteadyMeds pharmacy – SteadyMeds pharmacy

  16. canadian valley pharmacy: vipps approved canadian online pharmacy – vipps approved canadian online pharmacy

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>