ajax会被取代,为什么我的ajax文章不能取代内容?

这篇博客讨论了在ASP.NET MVC应用中,使用Ajax更新购物车商品数量时遇到的问题。作者通过`Ajax.BeginForm`调用`IncreaseProductQuantity`控制器方法更新商品,但在返回局部视图后,页面内容未正确刷新。在Chrome开发者工具中发现了一个内部服务器错误。社区建议检查Ajax请求的返回值,并在浏览器的开发者工具中查看更多信息以定位问题。
摘要由CSDN通过智能技术生成

@Html.Action("MiniShoppingCart", "ShoppingCart")

其中MiniShoppingCart动作返回MiniShoppingCart.cshtml局部视图的所有内容。

在这个局部视图我增加了一个Ajax调用增加产品车的数量:

@using (Ajax.BeginForm("IncreaseProductQuantity", "ShoppingCart", new { shoppingCartItemId = item.Id }, new AjaxOptions { UpdateTargetId = "miniShoppingCartContainer", InsertionMode = InsertionMode.Replace }))

{

}

它调用的方法:

public ActionResult IncreaseProductQuantity(int shoppingCartItemId)

{

//get shopping cart item

var cart = _workContext.CurrentCustomer.ShoppingCartItems

.Where(x => x.ShoppingCartType == ShoppingCartType.ShoppingCart).ToList();

var sci = cart.Where(x => x.Id == shoppingCartItemId).FirstOrDefault();

if (sci == null)

{

return RedirectToRoute("ShoppingCart");

}

//update the cart item

_shoppingCartService.UpdateShoppingCartItem(_workContext.CurrentCustomer,

sci.Id, sci.Quantity + 1, true);

return MiniShoppingCart();

}

请注意,在方法结束时,我致电MiniShoppingCart ActionResult准备购物车并返回PartialView(如您在帖子开头处看到的那样)。

好,产品的更新正在发生细微但内容不刷新(或更换)...

能否请你指出我在哪里错了?

UPDATE:

否则与Chrome开发了检查。工具我觉得那样做时,后一个错误:

POST http://localhost/ShoppingCart/IncreaseProductQuantity?shoppingCartItemId=11 500 (Internal Server Error)

f.support.ajax.f.ajaxTransport.sendjquery-1.7.1.min.js:4

f.extend.ajaxjquery-1.7.1.min.js:4

ejquery.unobtrusive-ajax.min.js:5

(anonymous function)jquery.unobtrusive-ajax.min.js:5

f.event.dispatchjquery-1.7.1.min.js:3

f.event.add.h.handle.ijquery-1.7.1.min.js:3

2

很奇怪猜测是该日志的问题...基本上,如果我让调试我可以看到它所有的操作,直到MiniShoppingCart()方法return PartialView(model); ...

+0

你有没有包含在不显眼的AJAX JS文件''在你的视图/布局? –

2012-03-03 09:27:35

+0

是的,我有这个包括:'' –

2012-03-03 09:30:52

+0

您应该检查在浏览器的开发控制台(IE/Chrome F12)或FireBug中,“IncreaseProductQuantity”正在返回。也许你会看到提示什么不起作用。 –

2012-03-03 09:42:59

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值