要做一个页面一跳转先出现_数据加载中,请稍后。_一个加载图片,等数据加载完全后再显示页面
试了几种方式,都不行,不是一直在loading就是加进去的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:'
//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 写一个隐藏加载页面的fun (loadfun)
在body onload="loadfun()"