


How to Apply Class Validation to Dynamic Textboxes in a Table Using jQuery Unobtrusive Validation?
Setting Class Validation for Dynamic Textboxes in a Table
Understanding the Problem
You have a dynamic table with textboxes, and you want to apply class validation to all these textboxes. jQuery's unobtrusive validation is not registering the added textboxes, resulting in the validation not working.
Addressing the Issue
To resolve this, you need to:
- Add data attributes: Include the necessary data-val attributes to the textboxes.
- Generate placeholder elements: Create placeholder elements for displaying validation messages.
- Allow non-consecutive indexers: Include a hidden input for the indexer to enable non-consecutive indexers for the posted collection.
Updated HTML with Indexer Hidden Input
@for (int i = 0; i < Model.TargetInfo.Count; i++) { <tr> <td> @Html.TextBoxFor(m => m.TargetInfo[i].TargetColor_U, new { id = "", @class = "form-control" }) @Html.ValidationMessageFor(m => m.TargetInfo[i].TargetColor_U) <input type="hidden" name="TargetInfo.Index" value=@i /> </td> <!-- Other columns with similar markup --> </tr> }
Updated JavaScript with Non-Consecutive Indexers
var form = $('form'); var newrow = $('#newrow'); var tablebody = $('#tablebody'); $("#btnAddTarget").click(function() { var index = (new Date()).getTime(); var clone = newrow.clone(); clone.html($(clone).html().replace(/#/g, index)); var row = clone.find('tr'); tablebody.append(row); // Reparse the validator using unobtrusive validation form.data('validator', null); $.validator.unobtrusive.parse(form); });
Additional Tips
- Unobtrusive validation re-parsing is required after adding dynamic content.
- Hidden indexers enable deleting non-consecutive rows.
- Use CSS for styling instead of inline styles.
- Consider using partial views for maintainability.
The above is the detailed content of How to Apply Class Validation to Dynamic Textboxes in a Table Using jQuery Unobtrusive Validation?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The Svelte transition API provides a way to animate components when they enter or leave the document, including custom Svelte transitions.

If you’ve recently started working with GraphQL, or reviewed its pros and cons, you’ve no doubt heard things like “GraphQL doesn’t support caching” or

How much time do you spend designing the content presentation for your websites? When you write a new blog post or create a new page, are you thinking about

With the recent climb of Bitcoin’s price over 20k $USD, and to it recently breaking 30k, I thought it’s worth taking a deep dive back into creating Ethereum

No matter what stage you’re at as a developer, the tasks we complete—whether big or small—make a huge impact in our personal and professional growth.

I'd say "website" fits better than "mobile app" but I like this framing from Max Lynch:

It's out! Congrats to the Vue team for getting it done, I know it was a massive effort and a long time coming. All new docs, as well.

npm commands run various tasks for you, either as a one-off or a continuously running process for things like starting a server or compiling code.
