My viewmodel contains a list of strings:
public class SupplierViewModel
{
public Supplier Supplier { get; set; }
public List<string> Numbers;
}
The user can add any number of strings in the view:
<div class="editor-label">
@Html.LabelFor(model => model.Numbers)
</div>
<div id="allNumbers">
@for (int i = 0; i < Model.Numbers.Count; i++)
{
<div class="editor-label">
@Html.TextBoxFor(m => m.Numbers[i])
</div>
}
</div>
<div id="newNumber" style="display:none;">
<input type="text" name="Numbers[#]" style="display:block;" />
</div>
<button type="button" id="addNumber" >Add</button>
This is done on the client side with jquery:
var container = $('#allNumbers');
$('#addNumber').click(function () {
var index = container.children().length;
var clone = $('#newNumber').clone();
clone.html($(clone).html().replace(/[#]/g, '[' + index + ']'));
container.append(clone.html());
});
My problem is that none of the dynamically added strings are sent back to the controller even tough they are all named "Numbers[i]".
What am I missing here?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…