我有以下HTML:某些HTML不想在IE中显示/隐藏。为什么?
<div id="loading-overlay">
<div id="loading-overlay-background"></div>
<div id="loading-overlay-content">
Processing...
<br />
<img src="@Url.Content("~/Content/img/ajax-loader.gif")" title="" alt="Please Wait" />
</div>
</div>
而CSS:
#loading-overlay
{
position:fixed;
width:100%;
height:100%;
top:0;
left:0;
z-index:5000;
}
#loading-overlay-background
{
position:relative;
width:100%;
height:100%;
top:0;
left:0;
background-color:#000;
opacity:0.5;
filter:alpha(opacity=50);
z-index:5001;
}
#loading-overlay-content
{
position:fixed;
top:25%;
left:50%;
margin-left:-150px;
margin-top:-20px;
height:40px;
width:300px;
color:#fff;
text-align:center;
z-index:15002;
}
这里是一些JavaScript(jQuery的):
$.ajax({
url: 'controller/action',
beforeSend: function() {
$('#loading-overlay').show();
},
success: function (data, textStatus, jqXHR) {
},
error: function (xhr) {
},
complete: function() {
$('#loading-overlay').hide();
}
});
为什么不是我的“加载覆盖“在任何AJAX调用中出现在任何版本的IE中?
编辑:是的,它在FireFox和Chrome中很好用。这些AJAX调用可能需要几分之一秒到20秒左右才能完成。警报消息确实显示,但HTML不显示。
AJAX调用需要多快才能完成?如果它们足够快,'#loading-overlay'元素将显示然后再次隐藏并且可能不明显。 – 2012-02-13 15:43:58
它适用于其他浏览器? – Christoph 2012-02-13 15:44:24
我会说ajax正在快速完成。在show()调用之后放一个提示,看看它是否显示 – Henesnarfel 2012-02-13 15:44:47