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

  1. pharmacy online: world pharmacy india – reputable online pharmacy no prescription

  2. when will pokies reopen south united states, no id casino uk and casino
    sarnia ontario australia, or canadian online casino sign up no deposit bonus

    Have a look at my homepage … blackjack real estate llc (Shelton)

  3. Tiger Casino

    Если ищешь tiger casino telegram, этот вариант выглядит нормальным. Я уже проверил его. Работает стабильно, без проблем. Можно использовать

  4. trustworthy online pharmacy FormuLine Pharmacy top-rated online pharmacies

  5. AccessBridge: AccessBridge – AccessBridge Pharmacy

  6. https://t.me/s/tigerCASINOofficial

    Казино тайгер сейчас проще всего найти через телеграм. Я перепробовал несколько ссылок и остановился на этой. Работает стабильно, без лишних заморочек. Вполне удобный вариант

  7. Казино Тайгер

    Если ищешь tiger casino официальный источник, стоит проверить этот вариант. Я уже тестировал его. Все работает нормально. Использую регулярно

  8. SteadyMeds pharmacy: SteadyMeds pharmacy – SteadyMeds pharmacy

  9. top-rated online pharmacies: FormuLine Pharmacy – best rx pharmacy online

  10. Hello I came across a 168 helpful resource that I think you should dive into. This tool is packed with a lot of useful information that you might find insightful. It has everything you could possibly need so be sure to give it a visit https://www.lexikon-fische.de/artikel-exotische-fische.shtml And do not neglect guys — a person constantly can within the article locate answers to address your the absolute tangled inquiries. The authors attempted to present all of the data via the most very understandable way.

  11. reputable mexican pharmacy: mexico online farmacia – mexico meds

  12. Казино Тайгер

    Если нужен тайгер казино сайт или канал, лучше использовать проверенные варианты. Я остановился на этом. Работает стабильно. Без лишних проблем

  13. online pharmacies in mexico: progreso mexico pharmacy online – AccessBridge

  14. VPN для телефона NaSvyziVPN – это больше, чем просто VPN, это ваш ключ к беспрепятственному доступу к информации. Наш сервис разработан с учетом ваших потребностей, будь то VPN для Telegram, YouTube, Instagram, TikTok или WhatsApp.

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>