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

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

  1. эпикстар казино зеркало сегодня
    ?
    Многие думают, что достаточно просто нагуглить «епикстар Casino зеркало», но в выдаче полно фишинговых копий; куда надёжнее взять ссылку из официального телеграм?канала, где модеры сами проверяют каждое зеркало и заранее предупреждают о подменах и блокировках.

  2. canada no deposit bonus casino, free pokies in united states and australia casino online real money, or android
    aspers casino 10 free (Lucille) united states

  3. blackjack usa free game download casino, canadian reasons why gambling is good (Kami) statistics 2021
    and best casino sites in canada, or online casino canada free chip

  4. Le gГ©nГ©rique de Viagra: Viagra homme prix en pharmacie sans ordonnance – Sildenafil teva 100 mg sans ordonnance

  5. best awesome online casinos [Tia] poker usa real money, united statesn no deposit free spins
    and bet365 blackjack hints uk, or 888 poker deposit new zealand

  6. farmacia online usa: hydrocodone mexico pharmacy – pharmacy delivery

  7. yard casino
    ?
    Нашел официальный канал Ярд казино, теперь не приходится искать рабочие адреса вручную.

  8. casino yard
    ?
    Официальный Telegram-канал Yard Casino — место публикации рабочих ссылок, зеркал и новостей проекта.

  9. Quand une femme prend du Viagra homme: Viagra sans ordonnance 24h Amazon – Viagra sans ordonnance 24h suisse

  10. Viagra 100 mg sans ordonnance: Viagra femme sans ordonnance 24h – Le gГ©nГ©rique de Viagra

  11. ufc 330 start time: Islam Makhachev – islam makhachev ufc

  12. Обратиться за помощью стоит если состояние больного ухудшается человек не может самостоятельно остановить употребление алкоголя агрессивно ведет себя жалуется на боли бессонницу тревогу депрессии рвоту тремор сильную интоксикацию или физические симптомы отмены. В таких случаях важно действовать быстро: срочный вызов нарколога на дом снижает риск осложнения отравления судорог и последствий длительного запоя. Подробнее – нарколог на дом недорого в казани

  13. ufc 330 start time: ufc 330 start time – islam makhachev ufc

  14. казино ярд
    ?
    У Ярд казино вся основная информация собрана в официальном телеграм-канале, включая зеркала и обновления сайта.

  15. norm casino
    ?
    В официальном канале Norm Casino доступны актуальные ссылки и информация о работе сайта.

  16. ufc fight night: ufc 330 fight card – Islam Makhachev

  17. islam makhachev ufc: ufc fight night – ufc fight night

  18. пин ап актуальный урл пин ап pin up kz пин ап казино

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>