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

  1. spark dex SparkDex is redefining decentralized trading with speed security and real earning potential. On spark dex you keep full control of your assets while enjoying fast swaps and low fees. Powered by sparkdex ai the platform delivers smarter insights and optimized performance for confident decision-making. Trade earn from liquidity and grow your crypto portfolio with sparkdex — the future of DeFi starts here.

  2. zoloft generic: zoloft without rx – zoloft tablet

  3. ivermectin oral solution: Iver Therapeutics – Iver Therapeutics

  4. аренда минивэна мерседес с водителем Выбирая аренду Mercedes-Benz V-Class с водителем в Москве вы получаете не только роскошный автомобиль но и профессионального шофёра отлично знающего городские маршруты и готового обеспечить пунктуальность и спокойствие в пути. Особое внимание уделяется трансферам в аэропорты Шереметьево Домодедово Внуково и Жуковский где точность и своевременность играют ключевую роль.

  5. canadapharmacyonline: Smart GenRx USA – Smart GenRx USA

  6. Kasyno Vavada oferuje szeroki wybor slotow i atrakcyjne promocje dla nowych graczy.
    Darmowe spiny oraz kody bez depozytu pozwalaja przetestowac gry bez ryzyka utraty srodkow.
    Aktualne lustra zapewniaja nieprzerwany dostep do strony nawet przy blokadach operatorow.
    Sprawdz biezace promocje i warunki obrotu przed aktywacja bonusu, aby uniknac niespodzianek przy wyplacie.
    Szczegoly i najnowsze kody znajdziesz tutaj: casino vavada.
    Graj odpowiedzialnie – ustaw limity i sledz historie transakcji w panelu uzytkownika.

  7. теплоход с аудиогидом по москве реке Экскурсия на теплоходе Москва-Сити: современная Москва.

  8. Приехал в Ростов искал проституток в телеграме — нашёл нормальный чат. Лучшие проститутки индивидуалки знакомятся договариваются о встречах. Вот ссылка: https://t.me/Rostov_Znakomst

  9. ivermectin purchase: Iver Therapeutics – ivermectin 8000

  10. аренда микроавтобуса мерседес с водителем аренда минивэна мерседес с водителем Москва

  11. order pharmacy online egypt: us pharmacy – Smart GenRx USA

  12. drug neurontin: buy neurontin 100 mg – cost of neurontin

  13. sparkdex SparkDex is redefining decentralized trading with speed security and real earning potential. On spark dex you keep full control of your assets while enjoying fast swaps and low fees. Powered by sparkdex ai the platform delivers smarter insights and optimized performance for confident decision-making. Trade earn from liquidity and grow your crypto portfolio with sparkdex — the future of DeFi starts here.

  14. online pharmacy indonesia 24 hour pharmacy near me us pharmacy no prescription

  15. аренда v class с водителем Выбирая аренду Mercedes-Benz V-Class с водителем в Москве вы получаете не только роскошный автомобиль но и профессионального шофёра отлично знающего городские маршруты и готового обеспечить пунктуальность и спокойствие в пути. Особое внимание уделяется трансферам в аэропорты Шереметьево Домодедово Внуково и Жуковский где точность и своевременность играют ключевую роль.

  16. cheapest pharmacy for prescriptions without insurance: Smart GenRx USA – Smart GenRx USA

  17. Комьюнити в 7k официальный сайт дружелюбное советы полезные.

  18. Neuro Relief USA: Neuro Relief USA – Neuro Relief USA

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>