gpt4 book ai didi

javascript - 将部分 View 加载到 JQuery 对话框中的缓存问题

转载 作者:行者123 更新时间:2023-11-30 08:58:14 25 4
gpt4 key购买 nike

想象一下带有“编辑”链接的简单用户列表。单击“编辑”会打开一个对话框,其中包含所选用户的详细信息。 “详细信息”弹出窗口是局部 View 。

在 JQuery 对话框窗口中打开分部 View 时,我遇到了缓存分部 View 的问题。

我的局部 View (请注意 OutputCache 属性是我尝试解决缓存问题的方法之一):

    [HttpGet]
[OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")]
public PartialViewResult EditUser(int id)
{
var userList = userRepository.GetByRole(id);

return PartialView("EditUser",userList);
}

上面的 PartialView 是从以下 Javascript 函数请求和加载的:

function editUserOpen(id) {

$.ajaxSetup({ ///// Another thing I tried to solve caching
cache: false
});

var url = "/User/PartialViewResult/" + id;

$('#user-wrap').empty().load(url, function () {

$("#dialog-edit-user").dialog({
title: "Edit User",
autoOpen: false,
height: 300,
width: 500,
modal: true
});

$('#dialog-edit-user').dialog("open");
});
}

如上所示,“dialog-edit-user”(以及“dialog-add-user”和“dialog-delete-user”)位于 DOM 中的“user-wrap”Div 内。

功能上一切正常,但是当我打开一个对话框时,取消然后尝试为其他用户打开对话框,直到页面刷新,对话框将始终包含最初显示的对话框中的信息。我认为这是一个缓存问题,但我没有办法解决它。

如果可能的话,我想远离 $.ajax({ cache:false; }).html(content) 。在我看来,它比 .load() 慢很多。

最佳答案

这是我的发现。

每次使用 .dialog() 初始化 JQuery 对话框时,如上所示,弹出的 div 被从 DOM 中取出并移动到页面底部。 Dialog Div 不能是另一个 Div 的子级。在我的例子中是:

<div id="user-wrap">
<div id="dialog-edit-user"> /// <--- Jquery dialog div

</div>
</div>

Dialog 不能包裹在其他div 中。

第一次点击后,当显示对话框时,JQuery 只是开始在页面底部累积重复的 Div。 $("#").dialog('open') 每次都打开累积重复的最顶层 DIV,使程序员/用户认为这是一个缓存问题。

因此解决方案是在 .dialog({close: } 事件中从页面底部删除由 JQuery 创建的 div,或者使用 JQuery 将其移回父包装器 DIV .append()/.appendTo() 函数。

希望这对遇到类似问题的下一个程序员有所帮助。

关于javascript - 将部分 View 加载到 JQuery 对话框中的缓存问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11528196/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com