我有以下问题:
“礼物”的集合作为参数传递给视图。此集合中的每个项目都是模型类“Gift”中的一个对象。这个类中只有两个属性:名称和价格。为了简单起见,我将类放在控制器中。
这是动作方法:
// GET: Order/CreateGift
[HttpGet]
public ActionResult CreateGift()
{
var initialData = new[]
{
new Gift{ Name = "Tricycle", Price = 69.95 },
new Gift{ Name = "PS4 game", Price = 29.99 },
new Gift{ Name = "Lazergun", Price = 49.99}
};
return View(initialData);
}
在视图中,我可以动态地将新项目添加到集合中,这要归功于 BeginCollectionItem Html 帮助器。
这是我的观点:
@model IEnumerable<DemoWebShop.Controllers.Gift>
<script src="~/Scripts/jquery-3.4.1.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$("#addItem").click(function () {
$.ajax({
url: this.href,
cache: false,
success: function (html) { $("#editorRows").append(html); }
});
return false;
});
}); // end document.ready function
</script>
<h2>Gift List</h2>
What do you want for your birthday?
@using (Html.BeginForm())
{
<div class="form-horizontal">
<div id="editorRows">
@foreach (var item in Model)
{
Html.RenderPartial("GiftEditorRow", item);
}
</div>
@Html.ActionLink("Add another...", "BlankEditorRow", null, new { id = "addItem" })
<input type="submit" value="Finished" />
@*<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Aanmaken" class="btn btn-default" />
</div>
</div>*@
</div>
}
这是名为“GiftEditorRow”的局部视图:
@using HtmlHelpers.BeginCollectionItem
@model DemoWebShop.Controllers.Gift
@{
Layout = null;
}
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="editorRow">
@using (Html.BeginCollectionItem("gifts"))
{
<label>Name: </label>
@Html.TextBoxFor(x => x.Name);
<label>Price: </label>
@Html.TextBoxFor(x => x.Price, new { size = 4 });
<br />
}
</div>
}
在我的控制器内部,我也有这个动作方法:
public ViewResult BlankEditorRow()
{
return View("GiftEditorRow", new Gift());
}
只有集合中已经存在的第一项被传递到我的控制器中的 HTTP Post 方法。