0

我想将选定的按钮值传递给控制器​​。请参阅下面的代码。

在我的控制器中,我传递了 ProductId,然后我将使用它在我的控制器中设置我的产品值。

控制器:

public ActionResult PlaceOrder(int ProductId, string OrderType)
{
  // Do something
}

在我的视图中,我有一个 foreach 循环,它将创建类似按钮的单选按钮,并且我还有一个 hiddenfor(SelectedProductId)

看法:

<div class="panel panel-primary">
  <div class="panel-heading">Panel Name</div>
  <div class="panel-body">
    <div class="row">
      <div class="form-group">
        @Html.HiddenFor(m => m.SelectedProductId)
        @if (Model.Products != null && Model.Products.Count > 0)
        {
          <div class="btn-group" data-toggle="buttons">
          @foreach (var product in Model.Products)
          {
            <label class="btn btn-default productButton">        
              <div class="labelProduct">@Product.Name</div>
              <input type="radio" name="ProductGMX" id="@("product" + @product.Id)" autocomplete="off" checked data-id="@product.Id">
            </label>
          }
        </div>

我想在 ActionLink 中传递产品 ID,然后将其传递给控制器​​,但我不确定如何实现

按钮点击:

@Html.ActionLink("Order with standard delivery", "PlaceOrder", "Standard", new { ProductId = ?,  OrderType = "Standard delivery" }, new { area = "Standard" })
@Html.ActionLink("Order with Next day Delivery", "PlaceOrder", "Elevated", new { ProductId = ?, OrderType = "NextDay" }, new { area = "Elevated", })
4

2 回答 2

0

每当产品发生变化时,您都需要使用 JavaScript 更新 ActionLink 的 url,使用单选按钮中的 data-id。

或者

使用提交按钮而不是 ActionLinks,并将单选按钮上的值设置为产品 ID。您需要在控制器中添加一些逻辑来处理两个不同的按钮。

于 2015-03-18T14:11:59.123 回答
0

那些不是按钮。它们是链接,不参与表单提交。

使用真正的按钮,即<button></button>给他们一个名字。然后您可以通过检查Request对象来查看单击了哪个:

<button name="_StandardDelivery">Order with standard delivery</button>

然后在你的行动中:

if (Request["_StandardDelivery"] != null) {
    // user chose standard delivery
}
于 2015-03-18T14:35:01.513 回答