【发布时间】:2011-12-29 03:54:41
【问题描述】:
使用 ASP.NET MVC3 (Razor) 我有一个加载 jQuery UI 对话框的简单页面。
@{
ViewBag.Title = "Home Page";
}
<h2>yo</h2>
<div id="fileUpload">
</div>
<button id="button2">
Upload file
</button>
<script type="text/javascript">
$(document).ready(function () {
$('#button2').click(function () {
$fileUpload = $('#fileUpload');
$fileUpload.dialog({
minWidth: 500,
minHeight: 100,
title: 'Upload File(s)',
autoOpen: true,
buttons: {
'Upload': function () {
$('form').submit();
},
'Cancel': function () {
$(this).dialog('close');
}
},
open: function (event, ui) {
$(this).load('@Url.Action(MVC.FileUpload.FileUpload())');
},
close: function (event, ui) {
$(this).dialog('destroy');
//$(this).remove();
},
dialogClass: 'no-close',
closeText: '',
modal: true
});
});
});
</script>
注意 open() 表单调用控制器方法。它返回一个 PartialView,看起来像这样......
public virtual ActionResult FileUpload() { return new 部分视图结果(); }
我遇到的问题是 IE 正在缓存对局部视图的调用。如果我更新部分视图,则在我清除浏览器缓存之前它不会加载。
我已经在 close() 和 .remove() 上尝试过 'destroy' 方法。两者都没有效果。我还确认每次单击#button2 时都会调用 open()。
关于如何防止对话内容被缓存的任何想法?
【问题讨论】:
标签: jquery asp.net-mvc-3 razor jquery-ui-dialog