【发布时间】:2017-01-13 06:02:31
【问题描述】:
我在操作中有以下场景,我想更新给定购物车中所有商品的数量。我将数组发回我的购物车项目的控制器,并希望在用户更新它们时更新数量。我怎样才能做到这一点?这就是我所在的位置。
这是我购物车的视图
@model SeniorProjectMVC.Models.ViewModels.CartViewModel
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h3>Your cart</h3>
@*<p>
@Html.ActionLink("Create New", "Create")
</p>*@
<div class="row header-row">
<div class="large-1 columns">
<h4> Quantity</h4>
</div>
<div class="large-5 columns text-center">
<h4>Name</h4>
</div>
<div class="large-1 columns">
<h4>Price</h4>
</div>
<div class="large-2 columns">
<h4>In stock</h4>
</div>
<div class="large-3 columns"></div>
</div>
@{
int CurrentIndex = 1;
}
@for (int i = 0; i < Model.CartArray.Length; i++)
{
<div class="@(CurrentIndex % 2 == 0 ? "row primary-row" : "row alternate-row")">
<div class="large-1 columns">
@Html.EditorFor( m => m.CartArray[i].Quantity)
</div>
<div class="large-5 columns text-center">
@Html.DisplayFor(m => m.CartArray[i].Sku.Product.Name)
</div>
<div class="large-1 columns">
@*@Html.DisplayFor(m => m.CartArray[i].Sku.Product.Price)*@
@String.Format("{0:c}", (Model.CartArray[i].Sku.Product.Price * Model.CartArray[i].Quantity))
</div>
<div class="large-2 columns">
@( Model.CartArray[i].Sku.Quantity > 0 ? "In Stock" : "Out of stock")
</div>
<div class="large-3 columns">
<ul class="button-group">
@*<li class="button">@Html.ActionLink("Edit", "Edit", new { id = Model.CartArray[i].ID }, new { @class = "button primary" }) </li>*@
<li class="button">@Html.ActionLink("Remove", "Remove", new { id = Model.CartArray[i].ID }, new { @class = "button primary" })</li>
</ul>
@*@Html.ActionLink("Details", "Details", new { id = item.ID }, new { @class = "button primary" }) |*@
</div>
</div>
{ CurrentIndex = CurrentIndex + 1; }
}
<div clsas="row">
<div class="large-offset-8 columns">
<h5 class="inline">Subtotal:</h5><h4 class="inline">@(Model.CartArray.Sum(p => (p.Sku.Product.Price * p.Quantity)).ToString("c"))</h4>
</div>
</div>
<div class="row">
<div class="medium-offset-8 medium-4 columns">
<ul class="button-group">
<li class="button">@Html.ActionLink("Update Quantities", "UpdateQuantities", "Cart", new { array = Model.CartArray }, new { @class = "button primary large" })</li>
@if (Request.IsAuthenticated && User.Identity.IsAuthenticated)
{
<li class="button">@Html.ActionLink("Checkout", "Address", "Checkout", null, new { @class = "button primary large" })</li>
}
else
{
<li class="button secondary">You must sign in to checkout</li>
}
</ul>
</div>
</div>
这是我想将数量发布回控制器的操作,然后更新我的数据库上下文类。我不确定实现这一目标的最有效方法或方法是什么。
public ActionResult UpdateQuantities(Models.ViewModels.CartViewModel cartModel)
{
for (int i = 0; i < cartModel.CartArray.Length; i++)
{
//either update each record, or build a list to do one mass update.
//This is where I am stuck
}
return View();
}
【问题讨论】:
-
您需要将您的元素包装在一个表单中并将表单提交给一个 POST 方法(并删除您的按钮,这是一个 GET 并且不会发回您的模型 - 查看@987654323 @ 属性它生成以理解 - 如果它这样做,它将发送回原始数据,而不是编辑的数据)。您还需要额外的隐藏输入来识别集合中的项目。
-
所以我需要将它们包装在一个表单标签中,并为每个购物车项目的 ID 字段添加一个隐藏字段,对吗?
-
是的。
CartViewModel的任何属性,包括您希望在控制器中接收的CartArray集合的属性,都需要在@using (Html.BeginForm(...))中使用表单控件 -
你有什么我可以效仿的例子吗?我好像有问题
-
你有什么问题?
标签: c# asp.net-mvc entity-framework ef-code-first linq-to-entities