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

  1. For those seeking an exceptional online gaming experience us.comhttps://maxispin.us.com/ stands out as a premier destination. At Maxispin Casino players can enjoy a vast array of pokies table games and other thrilling options all accessible in both demo and real-money modes. The casino offers attractive bonuses including free spins and a generous welcome offer along with cashback promotions and engaging tournaments. To ensure a seamless experience Maxispin provides various payment methods efficient withdrawal processes and reliable customer support through live chat. Security is a top priority with robust safety measures and a strong focus on responsible gambling tools. Players can easily navigate the site with detailed guides on account creation verification and payment methods. Whether youre interested in high RTP slots hold and win pokies or the latest slot releases Maxispin Casino delivers a user-friendly and secure platform. Explore their terms and conditions read reviews and discover why many consider Maxispin a legitimate and trustworthy choice in Australia. Utilizing AI technology MaxiSpin.us.com makes sure your content excels in the competitive market. Features of MaxiSpin.us.com As a result it becomes a vital resource for global marketers and companies. Benefits of Using MaxiSpin.us.com Individuals and small businesses can equally benefit from MaxiSpin.us.com.

  2. buying from canadian pharmacies: US Pharma Index – pharmacy mall

  3. rx online pharmacy: online pharmacy india – US Pharma Index

  4. US Pharma Index: cost less pharmacy – US Pharma Index

  5. Аирдропы Крипта майнинг аирдропы и тапалки — всё самое свежее в Smart Money Crypto Зарабатывай на криптоиграх и фармилках прямо в Telegram. Пассивный доход с удовольствием и без вложений Заходи и забирай свою прибыль. ИЛИ Ищешь где заработать на крипте? Smart Money Crypto Новости криптоигры с выводом актуальные аирдропы и майнинг на телефоне. Тапалки и фармилки в Telegram для твоего пассивного дохода. Присоединяйся к команде Smart Money

  6. Buy generic 100mg Viagra online: Sildenafil Price Guide – best price for viagra 100mg

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>