6

我正在使用以下代码:

在正文标签内的布局页面中:

<div id="loading">
    <img src="/images/user_profile/ajax-loading.gif" alt="Loading.." />
</div>

在起始页中:

<script type="text/javascript">
      $(document).ready(function(){
      $(window).load(function(){
      $('#loading').fadeOut();
      });
      });
</script>

CSS:

div.loading{

   height: 100px;
   width: 100px;
   position: fixed;
   z-index: 1000;
   left: 50%;
   top: 50%;
   margin: -25px 0 0 -25px;
   display:block;
}

问题是旋转图像不会立即出现,由于出现空白页面并且图像在页面加载之前显示,因此需要一些时间。

我想要一个解决方案,其中应立即显示图像并直到加载整个页面。

4

5 回答 5

5

虽然有很多方法可以预加载图像(使用 CSS / Javascript 等),但对我来说可靠地用于小图像的一种方法是通过内联图像

<img src="" alt="Loading..." />

(注意:以上是来自AjaxLoad的真实加载微调器)

它可能不是最易读的,但它确实与文档一起加载。假设它很简单(小于 ~2Kb),它根本不会影响您的性能。

于 2013-05-29T09:45:41.427 回答
1

您应该确保您的脑海中没有大量阻塞 javascript。将所有 javascript 移动到页面底部。如果您的代码为此正确编写,还要在脚本上设置 async 属性,否则设置 defer 属性。

完成此操作后,请确保加载屏幕是正文中的第一个元素,这样可以确保尽早获取资源。如果您在加载动画之前有许多 css 加载、字体等,这就是导致下载图像延迟的原因,因为浏览器的出站连接已被其他下载饱和。因此,请尝试将下载次数保持在最低限度,或者将它们放在重要区域以下,或者使用异步资产加载器按需获取它们。

避免其他资源阻塞加载动画显示的最佳方法是在 html 中内联所有相关部分。在加载屏幕的 html 正上方内联 css,甚至可能将 gif 源内联为 base64 编码的数据 URI。

于 2013-05-29T10:40:22.250 回答
0

document.ready使用和的单独实例window.load

例子:

HTML

<img id="test" src="very_tiny_loading_img.gif" alt="Loading..." />
<img src="vary_large_img.jpg" />

JS

$(document).ready(function() {
 // executes when HTML-Document is loaded and DOM is ready
 alert("document is ready");
});
$(window).load(function(){
 // executes when complete page is fully loaded, including all frames, objects and images
 alert("window is loaded");
 $('#test').fadeOut();
});

使用警报(替换为您的代码)

http://jsfiddle.net/3f2VS/

注意:我在小提琴中使用@hexblot 加载 img,因为它是一个很好的技巧来加载像这样的小 img ;-)

于 2013-05-31T08:33:36.203 回答
0

我认为当您提到 document.ready 中的代码时,它将在所有 dom 设置后触发....而不是使用 $(window).load(),然后它会在窗口加载后立即触发事件。

于 2014-06-21T09:52:33.223 回答
0

我在我的html中写了这个并且它有效。但我建议你把它们放在单独的文件中

<style>
.no-js #loader { display: none;  }
.js #loader { display: block; position: absolute; left: 100px; top: 0; }
.se-pre-con {
position: fixed;
left: 0px;
top: 0px;
width: 100%;
height: 100%;
z-index: 9999;
background: url("http://smallenvelop.com/wp-content/uploads/2014/08/Preloader_8.gif") center no-repeat #fff;

}

<script src="http://cdnjs.cloudflare.com/ajax/libs/modernizr/2.8.2/modernizr.js"></script>

<script>
$(window).load(function() {
    // Animate loader off screen
    $(".se-pre-con").fadeOut("slow");;
});
</script>

<div class="se-pre-con"></div>'
于 2015-08-30T14:47:25.660 回答