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

  1. mexican drug store mexican pharma mail order pharmacies

  2. fotsvamp handsprit: body hund apotek – halstablett apotek

  3. my mexican pharmacy: good online mexican pharmacy – pharmacy in mexico that ships to us

  4. Acheter Sildenafil 100mg sans ordonnance SildГ©nafil 100 mg prix en pharmacie en France Viagra sans ordonnance pharmacie France

  5. mexico online pharmacy: mexican drugstore – pharmacy mexico city

  6. inositol apotek: apotek hemleverans – Svenska Pharma

  7. https://t.me/s/fly_casino_official
    ?
    Если вы цените честные обзоры, посмотрите ветку обсуждений под постами в официальном канале Fly Casino: там обсуждают качество поддержки, отыгрыш бездепов, поведение слотов и реальные кейсы по ограничению ставок, что полезнее анонимных отзывов на форумах.

  8. fly casino
    ?
    Когда вы подписаны на официальный Fly Casino в тг, вы по сути подписаны на оперативный changelog бренда: новые игры, турниры, изменения по зеркалам и даже новости по регуляции приходят в виде коротких сообщений.

  9. https://t.me/s/fly_casino_official
    ?
    Даже если вы не сидите в тг каждый день, можно просто закрепить чат Fly Casino вверху: когда понадобится рабочее зеркало или apk, вы сразу увидите нужный канал и не будете путаться между клоновскими каналами с похожими названиями.

  10. Svenska Pharma: vitamin d apotek – Svenska Pharma

  11. Г¶ka testosteron apotek Svenska Pharma Svenska Pharma

  12. fly casino tg
    ?
    Когда я впервые увидел надпись «зеркало на сегодня» прямо в заголовке поста, стало ясно, где искать актуальный домен; дальше уже не экспериментировал с другими источниками.

  13. https://t.me/s/fly_casino_official
    ?
    С телефона удобнее всего: нажал на ссылку в посте, браузер открыл зеркало, авторизация по сохранённым данным – не нужно каждый раз вводить домен руками.

  14. https://t.me/s/fly_casino_official
    ?
    Заметил, что многие пишут «Флай казик тг», но потом попадают на фейк; у оффициального канала другая аватарка и закреп, так что смотрите внимательно, чтобы не слить логин.

  15. generic sildenafil: order viagra – Macksood Urology

  16. ed medications cost: Macksood Urology Urological Services – how to get ed meds online

  17. Tadalafil price Macksood Urology Urological Services Macksood Urology Urological Services

  18. Норм Казино
    ?
    Чтобы не путаться в промокодах, админка канала Норм казино регулярно собирает все действующие предложения в одном посте и помечает, какие из них привязаны к конкретным зеркалам, а какие работают глобально.

  19. п»їcialis generic: Macksood Urology – Generic Cialis without a doctor prescription

  20. Norm Casino зеркало сегодня
    ?
    Часто вижу вопрос «есть ли официальный телеграм Norm casinо», так вот – он один, и если вы в нём, то все эти зеркала с непонятными доменами можно смело игнорировать.

  21. выплаты Норм казино
    ?
    Если вы не хотите каждый раз искать официальный сайт Norm Casino через поисковик, просто закрепите ссылку на их телеграм?канал: внутри всегда лежит рабочая ссылка на сайт, инструкция по входу и объяснение, какие домены на сегодня считаются основными.

  22. бездепы Norm Casino
    ?
    Часто вижу вопрос «есть ли официальный телеграм Norm casinо», так вот – он один, и если вы в нём, то все эти зеркала с непонятными доменами можно смело игнорировать.

  23. Macksood Urology Urological Services: Macksood Urology – Macksood Urology

  24. Norm Casino официальный сайт
    ?
    Когда у кого?то из друзей возникает вопрос «почему сайт Norm Casino не открывается?», проще отправить ему ссылку на официальный телеграм?канал, чем объяснять длинными текстами; там он сам найдёт актуальное зеркало и инструкцию.

  25. order ed pills online Macksood Urology Urological Services ed online treatment

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>