JS实现页面加载完毕之前loading提示效果
引用:http://qubernet.blog.163.com/blog/static/1779472842014510392573/
做成js调用:
base-loading.js代码
-
/*******************************************
-
*
-
* 创建人:Quber([email protected])
-
* 创建时间:2014年6月10日
-
* 创建说明:Base=>页面加载(loading)效果
-
*
-
* 修改人:
-
* 修改时间:
-
* 修改说明:
-
*
-
*********************************************/
-
//获取浏览器页面可见高度和宽度
-
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/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);
-
}
-
}
一、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(/Content/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);
-
}
-
}
二、效果:
说明:
将此段js代码放入<head>最后即可;
其中loading效果的样式可以根据自己的风格修改,loading.gif这个图片需要自己找(网上很多的)。