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

  1. Ivermectin Access USA: buy stromectol online uk – Ivermectin Access USA

  2. заказать кухню в интернете [url=https://zakazat-kuhnyu-3.ru/]заказать кухню в интернете[/url] .

  3. Казино Vavada привлекает игроков щедрыми бонусами без депозита и постоянными турнирами с крупным призовым фондом.
    Регистрация занимает несколько минут, а рабочие зеркала обеспечивают стабильный доступ к сайту даже при блокировках.
    Проверяйте актуальные промокоды и условия отыгрыша, чтобы оптимально использовать стартовые фриспины.
    Служба поддержки отвечает на русском языке и помогает решить вопросы с верификацией и выводом средств.
    Свежие предложения и актуальное зеркало доступны по ссылке: вавада казино.
    Играйте ответственно и контролируйте банкролл, чтобы азарт приносил удовольствие.

  4. заказать полиграфическую продукцию [url=xn--http://-5gga3h0d.xn--/forum/topic-ugk8c.php?forum=3&topic=2655/]xn--http://-5gga3h0d.xn--/forum/topic-ugk8c.php?forum=3&topic=2655[/url] .

  5. купить кухню в пскове Мы предлагаем полный спектр услуг: от создания уникального дизайна до установки готового кухонного гарнитура чтобы ваша новая кухня стала не просто местом для готовки а сердцем вашего дома наполненным теплом и уютом. В нашей студии вы можете «заказать кухню в Пскове» которая будет полностью соответствовать вашим предпочтениям и бюджету ведь «кухня на заказ Псков цены» всегда прозрачны и доступны.

  6. проект перепланировки квартиры в москве [url=https://teletype.in/@jorik11/proekt-dlya-pereplanirovki/]проект перепланировки квартиры в москве[/url] .

  7. остров ко ланта в тайланде ко ланта аэропорт

  8. перепланировка москва [url=https://sites.google.com/view/dokument-dlya-pereplan/главная-страница/]sites.google.com/view/dokument-dlya-pereplan/главная-страница[/url] .

  9. Cheap generic Viagra: Sildenafil Price Guide – Generic Viagra for sale

  10. Ivermectin Access USA Ivermectin Access USA stromectol tab 3mg

  11. Казино Vavada привлекает игроков щедрыми бонусами без депозита и постоянными турнирами с крупным призовым фондом.
    Регистрация занимает несколько минут, а рабочие зеркала обеспечивают стабильный доступ к сайту даже при блокировках.
    Проверяйте актуальные промокоды и условия отыгрыша, чтобы оптимально использовать стартовые фриспины.
    Служба поддержки отвечает на русском языке и помогает решить вопросы с верификацией и выводом средств.
    Свежие предложения и актуальное зеркало доступны по ссылке: https://vluki.net/vavada.
    Играйте ответственно и контролируйте банкролл, чтобы азарт приносил удовольствие.

  12. Ivermectin Access USA: Ivermectin Access USA – Ivermectin Access USA

  13. Онлайн казино без верификации и паспорта Онлайн казино без верификации и паспорта .

  14. кухня в доме в классическом стиле Здесь мы делимся «рецептом идеального алгоритма» превращая сложные задачи в аппетитные решения а «ингредиенты успешного алгоритма» становятся понятными каждому.

  15. Cheap Viagra 100mg: Sildenafil Price Guide – cheapest viagra

  16. cheapest pharmacy: canada pharmacy not requiring prescription – indian pharmacy online

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>