4

我有一个 jQuery $.post 返回到 MVC 4 控制器,它将返回一个 PartialViewResult,并使用 POST 中发送的数据进行渲染。在调试 Partial View 和 Controller 时,正在接收正确的数据并将其作为 View Model 发送到 Partial View。问题是,在分析在 AJAX 结果中发回的 HTML 时,它包含来自原始页面刷新的看似“缓存”的数据。

我在这里看到了大量类似的帖子,但没有一个与我的问题相同。

我知道 HTTP Post 请求不会缓存在浏览器中,所以这不是问题。我还将 OutputCache 属性设置为 NoStore = true 等。

控制器

[OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")]
public partial class MyController : Controller
{ 
  ...
    [HttpPost]
    public virtual ActionResult UpdatePartial(MyViewModel myVm)
    {
        return this.PartialView("My/_Partial", myVm);
    }
}

JS

$('.someButton').click(function () {
        $.post(myAjaxUrl, $('form').serialize(), function (data) {
            $('#myContent').html(data);
        });
    });
4

2 回答 2

2

我可以通过ModelState.Clear在对模型进行任何操作之前添加来解决这个问题。

[HttpPost] 
public virtual ActionResult UpdatePartial(PersonViewModel model) 
{ 
    ModelState.Clear(); 
    model.FirstName += "1"; 
    model.LastName += "1"; 
    model.Age += 1; 
    return this.PartialView("../My/_Partial", model); 
}

这个问题有蒂姆斯科特的答案,其中包含更多信息和链接。

于 2013-02-18T02:22:17.017 回答
0

默认情况下,JQuery 将缓存 $.ajax XMLHttpRequests(除非数据类型是脚本或 jsonp)。由于 $.post 是通过 $.ajax 实现的,因此 JQuery 本身已经缓存了您的请求。以下JS应该可以工作。

JS

$('.someButton').click(function () {
    $.ajax{(
        url: myAjaxUrl,
        data: myAjaxUrl,
        success: function (data) {
           $('#myContent').html(data);
        },
        cache: false
    });
});

如果发布不成功,您可能还会发现处理错误事件是值得的。

于 2013-02-16T15:45:31.260 回答