网页Loading效果

问题描述:由于项目要求在页面提交以及加载的时候,有短暂的卡顿,需要用loading过渡。

1.下一个页面加载的时候实现:

base-loading.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: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(/Content/img/loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969; font-family:\'Microsoft YaHei\';">页面加载中,请等待...</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);
    }
}

页面调用代码:在head前面引入上面的JS,实现过渡效果。

    <script src="/Content/js/base-loading.js"></script>
</head>

2.页面提交时的过渡效果实现

A.首先在当前页面新建一个隐藏的加载页面的层

 <!-- loading 层 -->
    <div id="loadingDiv2" style="display: none;position:absolute; top: 0;left:0;width:100%;op:0;background:#f3f8ff;opacity:1;filter:alpha(opacity=80);z-index:10000;">
        <div id="loadingDiv3" style="position: absolute; cursor1: wait; width: auto; height: 57px; line-height: 57px; padding-left: 50px; padding-right: 5px; background: #fff url(/Content/img/loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969; font-family:\'Microsoft YaHei\';">页面加载中,请等待...</div>
    </div>
</body>

B.当提交按钮点击或者from的ajax提交时调用js,设置隐藏层的高度和位置并显示

说明:这里之所以用页面已经存在的div而不是沿用document.write(_LoadingHtml)动态输出一个div是因为如果动态输入div,在用户点击浏览器上面的上一页的时候会直接进入这个输出的div,导致一直处于loading状态页。

function showLoading() {
    var _PageHeight = $(document).height();//document.documentElement.clientHeight,
    _PageWidth = document.documentElement.clientWidth;
    //计算loading框距离顶部和左部的距离(loading框的宽度为215px,高度为61px)
    var _LoadingTop = $(document).scrollTop() + document.documentElement.clientHeight / 2;//折叠高度+1/2浏览器高度得到当前视图中间
        _LoadingLeft = _PageWidth > 215 ? (_PageWidth - 215) / 2 : 0;
    //隐藏层在_Layout_Survey_Edit.cshtml
    $("#loadingDiv2").height(_PageHeight);
    $("#loadingDiv3").css("left", _LoadingLeft + "px");
    $("#loadingDiv3").css("top", _LoadingTop + "px");
    $("#loadingDiv2").show();
}

C.调用showLoading函数

由于项目用的是Jeuery的数据验证引擎,因此在回调函数onAjaxFormComplete: ajaxValidationCallback中去调用loading函数

//表单验证 事件绑定
    if (!runFormBindingFlag) {
        jQuery('.js_form').submit(packUncheckItem);
        jQuery('.js_form').validationEngine({
            showOneMessage: true,
            ajaxFormValidation: true,
            ajaxFormValidationMethod: 'post',
            //onBeforeAjaxFormValidation: showLoading,
            onAjaxFormComplete: ajaxValidationCallback
        });
// 异步提交表格后 回调事件
function ajaxValidationCallback(status, form, json, options) {
    //由于loading效果出现后就无法取得当前页面的token  sUrl信息,因此先取出来
    var sUrl = $("#js_page_hide").attr("page");
    var token = $("#hidden_token").val();
    var currentUrl = "";
    showLoading();
    if (status === true) {
        // uncomment these lines to submit the form to form.action
        // form.validationEngine('detach');
        // form.submit();
        // or you may use AJAX again to submit the data
        //var currentUrl=location.href.substr(0,location.href.indexOf('/Page/')+6);
        if (location.href.indexOf('/Page/') > 0) {
            currentUrl = location.href.substr(0, location.href.indexOf('/Page/') + 6);
        }
        if (location.href.indexOf('/PageView/') > 0) {
            currentUrl = location.href.substr(0, location.href.indexOf('/PageView/') + 10);
        }
        //var sUrl = $("#js_page_hide").attr("page");
        //var token = $("#hidden_token").val();
        if(sUrl) {
            if(sUrl=='Executive_other_benefits') {
                sUrl="/Survey/submit/?token="+token;
                document.location=sUrl;
            }
            else {
                sUrl = currentUrl + sUrl + "?token=" + token + "&isNext=1";//&isNext=1"标记是点击下一页的情况
                document.location=sUrl;
            }
        }
    } else {
        window.location.reload();
        //document.location = currentUrl;//提交失败,则直接刷新
    }
}

由于ajax的异步提交,回调函数会先执行,然后等待服务器的返回status === true,因此将loading函数放在回调处理之前,回调过程中进行了页面跳转并且loading层初始设置为隐藏,因此不需要对loading层进行隐藏。

转载于:https://www.cnblogs.com/tylertang/p/5334650.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值