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).

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

  1. sertraline zoloft: zoloft without dr prescription – order zoloft

  2. Iver Therapeutics: ivermectin 10 ml – ivermectin pills

  3. zoloft no prescription: Sertraline USA – Sertraline USA

  4. Smart GenRx USA Smart GenRx USA online pharmacy europe

  5. zoloft medication: Sertraline USA – sertraline generic

  6. ivermectin tablets uk: ivermectin otc – ivermectin 12

  7. как выбирать одежду и обувь Как выбрать одежду – вопрос ответ на который лежит в плоскости понимания собственных потребностей и желаний. Одежда должна быть не только красивой но и удобной.

  8. Smart GenRx USA: Smart GenRx USA – pharmacy prices

  9. canadian pharmacy world: pharmacy near me – Smart GenRx USA

  10. Smart GenRx USA: pharmacy coupons – Smart GenRx USA

  11. stromectol price in india Iver Therapeutics Iver Therapeutics

  12. zoloft tablet: sertraline zoloft – zoloft without dr prescription

  13. pharmacy discount coupons: Smart GenRx USA – Smart GenRx USA

  14. теплоход с шоу-программой москва Тусовка на теплоходе — расписание рейсов: планируйте свои лучшие выходные с нами.

  15. фторопласт стержневой Резина пористая листовая: отличные амортизационные свойства

  16. Neuro Relief USA: where to buy neurontin – Neuro Relief USA

  17. ivermectin drug: buy ivermectin – Iver Therapeutics

  18. теплоход от кремля до москва-сити — маршрут2026 Короткий круиз от Крымского моста — 1 час билеты: быстрый заряд позитива.

  19. stromectol 6 mg tablet: Iver Therapeutics – Iver Therapeutics

  20. анонимный онлайн психолог Паническая атака лечение у взрослых: верните себе полноценную жизнь.

  21. sertraline zoloft: zoloft medication – sertraline zoloft

  22. прогулка на теплоходе с живой музыкой Тусовка на теплоходе — расписание рейсов: планируйте свои лучшие выходные с нами.

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>