【前言】
本文罗列总结下常见的JS案例,为以后备课做个参考。
【主体】
(1)页面加载完毕之前loading提示效果
<!DOCTYPE html>
<html>
<head>
<title>JS加载</title>
<script type="text/javascript">
//获取浏览器页面可见高度和宽度
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(loading.gif) no-repeat scroll 5px 10px; border: 2px solid #95B8E7; color: #696969;">页面加载中,请等待...</div></div>';
//呈现loading效果
document.write(_LoadingHtml);
window.onload = function () {
setTimeout(removeLoad,1000);
function removeLoad(){
var loadingMask = document.getElementById('loadingDiv');
loadingMask.parentNode.removeChild(loadingMask);
}
};
//监听加载状态改变
// document.onreadystatechange = completeLoading;
//加载状态为complete时移除loading效果
// function completeLoading() {
// if (document.readyState == "complete") {
// setTimeout(removeLoad,1000);
// function removeLoad(){
// var loadingMask = document.getElementById('loadingDiv');
// loadingMask.parentNode.removeChild(loadingMask);
// }
// }
// }
</script>
</head>
<body>
</body>
</html>
① 关于clientHeight和clientWidth可以参考文章浅谈JS各种宽高(clientHeight、scrollHeight、offsetHeight等)
②关于document.documentElement可以参考文章document.body 与 document.documentElement区别
(2)
.