2

这是我的控制器方法。

    [HttpPost]
    public ActionResult CheckStock(int productId, short units)
    {

        Product model = db.Products.Single(x => x.Product_ID == productId);
        model.Units_In_Stock = units;
        db.ObjectStateManager.ChangeObjectState(model, EntityState.Modified);
        db.SaveChanges();
        db.Refresh(System.Data.Objects.RefreshMode.ClientWins, model);
        var newModel = db.Products.Single(x => x.Product_ID == productId);

        return View("Details", newModel);
    }

这是我的 AJAX:

    <script src="/Scripts/jquery-1.5.1.min.js" 
    type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
            $(".UpdateProductId").click(function () {
                var unitsInStock = 123;
                var pId = $(this).attr("data-id");
                if (pId != '' || pId != null) {
                    $.post("/Product/CheckStock", { "productId": pId, "unitsInStock": unitsInStock },
                              function (data) {
                                  $('#units-in-stock').text(unitsInStock);
                              });
                }
                else {
                    alert("Product_ID is empty");
                }
            });
        }); 
    </script>

这是我的链接:

    <div>
        <a href="#" class="UpdateProductId" data-id="@Model.Product_ID">Update</a> 
    </div>

这是带有唯一受影响行的精简表格。

    <fieldset>
        <legend>Product</legend>
        <div class="display-label">
            <table>
                <tr><td>Units_In_Stock</td><td><div id="units-in-stock">@Html.DisplayFor(model => model.Units_In_Stock)</div></td></tr>
            </table>
        </div>
    </fieldset>

我根本没有收到任何错误,但是当我单击链接时什么都没有发生,除了 # 被添加到查询字符串中。控制器中 CheckStock 中的断点和 AJAX 方法中的断点没有被命中。请帮忙。

4

1 回答 1

2

您的键名和 CheckStockmethod 参数不一样,您unitsInStock在 ajax 请求中有但units在 CheckStock 方法中,将它们更改为匹配。

于 2013-03-13T00:51:46.350 回答