想要实现页面加载完成前不显示页面,或半透明显示页面,只显示loading提示,当页面加载完成后,提示消失显示正常页面。只需通过将以下代码加入<head>标签之间即可,方便实现,简单易懂。

<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: #161616  url(/背景图片.gif) top left repeat;opacity:0.9;filter:alpha(opacity=90);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; border: 0px solid #95B8E7; "><h8>Loading...</h8></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);
            }
        }
    </script>

显示效果见顶部图片。

当然,也可根据爱好自行设定提示内容,通过修改loading Html中的样式来实现。

参考文章:

JS实现页面加载完毕之前loading提示效果