在页面加载前先出现加载loading,页面加载完成之后再显示页面

在此加入一个关于页面加载成功之前先展现一个loading的案例:

如下代码写入js里放在html头部即可实现需求:添加的可以自己在css文件设置宽高,也可以放入一个background的gif的loading图片

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

var _LoadingHtml = '页面加载中,请等待...';

//呈现loading效果

document.write(_LoadingHtml);

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

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

下面这行代码没测试过,估计也有参考价值:

//获取浏览器页面可见高度和宽度
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(image/dd.png) 
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);
    }
}

 

转载于:https://www.cnblogs.com/Dark-fire-liehuo/p/10538125.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值