JS实现页面加载完毕之前loading提示效果

引用:http://qubernet.blog.163.com/blog/static/1779472842014510392573/

做成js调用:

JS实现页面加载完毕之前loading提示效果

 

base-loading.js代码

 

 

 
  1. /*******************************************

  2. *

  3. * 创建人:Quber([email protected]

  4. * 创建时间:2014年6月10日

  5. * 创建说明:Base=>页面加载(loading)效果

  6. *

  7. * 修改人:

  8. * 修改时间:

  9. * 修改说明:

  10. *

  11. *********************************************/

  12.  
  13. //获取浏览器页面可见高度和宽度

  14. var _PageHeight = document.documentElement.clientHeight,

  15. _PageWidth = document.documentElement.clientWidth;

  16. //计算loading框距离顶部和左部的距离(loading框的宽度为215px,高度为61px)

  17. var _LoadingTop = _PageHeight > 61 ? (_PageHeight - 61) / 2 : 0,

  18. _LoadingLeft = _PageWidth > 215 ? (_PageWidth - 215) / 2 : 0;

  19. //在页面未加载完毕之前显示的loading Html自定义内容

  20. var _LoadingHtml = '<div id="loadingDiv" style="position:absolute;left:0;width:100%;height:' + _PageHeight + 'px;top:0;background:#f3f8ff;opacity:1;filter:alpha(opacity=80);z-index:10000;"><div style="position: absolute; cursor1: wait; left: ' + _LoadingLeft + 'px; top:' + _LoadingTop + 'px; width: auto; height: 57px; line-height: 57px; padding-left: 50px; padding-right: 5px; background: #fff url(Image/loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969; font-family:\'Microsoft YaHei\';">页面加载中,请等待...</div></div>';

  21. //呈现loading效果

  22. document.write(_LoadingHtml);

  23.  
  24. //window.onload = function () {

  25. // var loadingMask = document.getElementById('loadingDiv');

  26. // loadingMask.parentNode.removeChild(loadingMask);

  27. //};

  28.  
  29. //监听加载状态改变

  30. document.onreadystatechange = completeLoading;

  31.  
  32. //加载状态为complete时移除loading效果

  33. function completeLoading() {

  34. if (document.readyState == "complete") {

  35. var loadingMask = document.getElementById('loadingDiv');

  36. loadingMask.parentNode.removeChild(loadingMask);

  37. }

  38. }


 

 

 

 

 

一、JS代码:

 

 
  1. //获取浏览器页面可见高度和宽度

  2. var _PageHeight = document.documentElement.clientHeight,

  3. _PageWidth = document.documentElement.clientWidth;

  4. //计算loading框距离顶部和左部的距离(loading框的宽度为215px,高度为61px)

  5. var _LoadingTop = _PageHeight > 61 ? (_PageHeight - 61) / 2 : 0,

  6. _LoadingLeft = _PageWidth > 215 ? (_PageWidth - 215) / 2 : 0;

  7. //在页面未加载完毕之前显示的loading Html自定义内容

  8. var _LoadingHtml = '<div id="loadingDiv" style="position:absolute;left:0;width:100%;height:' + _PageHeight + 'px;top:0;background:#f3f8ff;opacity:0.8;filter:alpha(opacity=80);z-index:10000;"><div style="position: absolute; cursor1: wait; left: ' + _LoadingLeft + 'px; top:' + _LoadingTop + 'px; width: auto; height: 57px; line-height: 57px; padding-left: 50px; padding-right: 5px; background: #fff url(/Content/loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969; font-family:\'Microsoft YaHei\';">页面加载中,请等待...</div></div>';

  9. //呈现loading效果

  10. document.write(_LoadingHtml);

  11.  
  12. //window.onload = function () {

  13. // var loadingMask = document.getElementById('loadingDiv');

  14. // loadingMask.parentNode.removeChild(loadingMask);

  15. //};

  16.  
  17. //监听加载状态改变

  18. document.onreadystatechange = completeLoading;

  19.  
  20. //加载状态为complete时移除loading效果

  21. function completeLoading() {

  22. if (document.readyState == "complete") {

  23. var loadingMask = document.getElementById('loadingDiv');

  24. loadingMask.parentNode.removeChild(loadingMask);

  25. }

  26. }


二、效果:

 

JS实现页面加载完毕之前loading提示效果

 

 

说明:

将此段js代码放入<head>最后即可;

其中loading效果的样式可以根据自己的风格修改,loading.gif这个图片需要自己找(网上很多的)。