js如何做等待页面加载效果

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js如何做等待页面加载效果相关的知识,希望对你有一定的参考价值。

  可以使用第三方的控件Developer-Express来实现;
  安装完Developer以后,从工具箱中拖一个ASPxLoadingPanel到页面中,设置必须的一个属性ClientInstanceName后面要用到,然后设置Modal的作用是点击按钮时时候需要抑制后面按钮的使用,也就是弹出来一个灰色的层。
  重点是后面的js,在body中添加下面的JS代码
  <script type="text/javascript" language="javascript">
Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(BeginRequestHandler);
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
function BeginRequestHandler(sender, args)
loading.Show();

function EndRequestHandler(sender, args)
loading.Hide();

</script>
  至此,页面中的所有按钮就加上了一个加载等待的效果。
参考技术A 现在页面里写好一个loading的效果,等DOM树或者页面全部完成后去掉这个loading的效果层。 参考技术B 具体有什么意义么?可以用ajax实现! 参考技术C 自己搜素下mask.js看看

两种页面加载等待效果的实现

第一种,当打开一个新的页面时,这个页面的加载时间可能会比较长,可以用以下js实现页面等待效果,将该js导入加载的页面即可使用

//获取浏览器页面可见高度和宽度
var _PageHeight = document.documentElement.clientHeight,
    _PageWidth = document.documentElement.clientWidth;
//计算loading框距离顶部和左部的距离(loading框的宽度为215px,高度为61px)
var _LoadingTop = _PageHeight > 61 ? (_PageHeight - 61) / 2 : 0,
    _LoadingLeft = _PageWidth > 215 ? (_PageWidth - 215) / 2 : 0;
//在页面未加载完毕之前显示的loading Html自定义内容
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(/images/loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969; font-family:‘Microsoft YaHei‘;">重置密码中,请等待... &nbsp;&nbsp;</div></div>‘;
//呈现loading效果
document.write(_LoadingHtml);

//window.onload = function () {
//    var loadingMask = document.getElementById(‘loadingDiv‘);
//    loadingMask.parentNode.removeChild(loadingMask);
//};

//监听加载状态改变
document.onreadystatechange = completeLoading;

//加载状态为complete时移除loading效果
function completeLoading() {
    if (document.readyState == "complete") {
        var loadingMask = document.getElementById(‘loadingDiv‘);
        loadingMask.parentNode.removeChild(loadingMask);
    }
}

第二种,当点击页面等待后台操作完成的时候,如果后台处理量比较大等待时间比较长,可以用以下方法实现,该方法基于easyUI,关于easyUI不再赘述

function onloading(){
    $("<div class="datagrid-mask"></div>").css({display:"block",width:"100%",height:$(window).height()}).appendTo("body");
    $("<div class="datagrid-mask-msg"></div>").html("执行中,请稍候。。。").appendTo("body").css({display:"block",left:($(document.body).outerWidth(true) - 190) / 2,top:($(window).height() - 45) / 2});
}
function removeload(){
    $(".datagrid-mask").remove();
    $(".datagrid-mask-msg").remove();
}

 

以上是关于js如何做等待页面加载效果的主要内容,如果未能解决你的问题,请参考以下文章

jQuery 页面加载等待特效,当数据加载完成效果消失的代码?

js中改变窗口重新加载一次.js页面怎么做

页面加载时自动滚动到指定位置!如何做

js中,如何等待多个图片加载完后再执行其他的js代码。

如何让页面加载完成后执行js

淘汰赛:在等待查询完成时加载页面