У меня есть представление с добавлением элемента в коллекцию: он добавляет меня в html, но когда я вызываю ActionResult, Model.TagModelsis все еще пуст (при запуске пуст).
<div id="tags_div">
<label id="add_tag">Hello</label>
@foreach (var item in Model.TagModels)
{
<div class="editor-field">
@Html.EditorFor(model => item.Name)
@Html.ValidationMessageFor(model => item.Name)
</div>
}</div>
<script type="text/javascript">
$(document).ready(function () {
var $newdiv1 = $('<div class="ui-button-text"><input class="text-box single-line" id="item_Name" name="item.Name" type="text" value="b" /><span class="field-validation-valid" data-valmsg-for="item.Name" data-valmsg-replace="true"></span></div>');
$("#add_tag").live("click", function () {
$(this).append($newdiv1);
return false;
});
});
</script>
Вот мойviewmodel:
public class QuestionTagViewModel
{
public QuestionModel QuestionModel { get; set; }
//private List<TagModel> _tagModels=new List<TagModel>(){new TagModel(){Name = "a"},new TagModel(){Name = "b"}};
private List<TagModel> _tagModels = new List<TagModel>();
public List<TagModel> TagModels
{
get { return _tagModels; }
set { _tagModels = value; }
}
}
Почему нет обновления для модели?Когда я изменяю другие свойства для статических элементов, все в порядке
РЕДАКТИРОВАТЬ МХОЛЛИС:
Спасибо Антону за ваш ответ:)
Теперь у меня есть
<script type="text/javascript">
$(document).ready(function () {
$("#addItem").click(function () {
$.ajax({
url: this.href,
cache: false,
success: function (html) { $("#tags_div").append(html); }
});
return false;
});
});
</script>
И tags_div:
<div id="tags_div">
<label id="add_tag">Hello</label>
@Html.ActionLink("Add another...", "BlankEditorRow", null, new { id = "addItem" })
@foreach (var item in Model.TagModels)
{
<div class="editor-field">
@Html.EditorFor(model => item.Name)
</div>
}</div>
И что метод PartialViewResult:
public PartialViewResult BlankEditorRow()
{
var x=PartialView("TagRow", new TagModel());
return x;
}
и частичное представление:
@*@using Szamam.Models
@model TagModel
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>*@
<div class="editor-field">
<input class="text-box single-line" id="[0].Name" name="[0].Name" type="text" value="b" />
</div>
Элементдобавляется, но когда fie actionresult, коллекция пуста: /
Так что должна быть другая причина: /