你把 引入 两个 js 文件 的 script 标签放在 div 标签的上面,就会先加载完js,再加载div了。
像这样:
<script src="a.js"></script>
<script src="b.js"></script>
<div id="c" class="d">
浏览器加载 html 页面内容是按从上到下的顺序一行行执行的。
相反,如果想div先加载,就把div写到script标签上面。
把js放在body的上方。网页的加载是按照从上往下的方式执行的。只要把js放在网页的最上方。
<head> //把js的加载放在head之间,就在页面节点加载显示之前就加载了js<script>
</script>
</head>
<body>
</body>
如果是纯文字内容的话可以不用管文档加载到哪里了就加载完成了
如果div下面有图片的话(img标签就需要进行判断了)
这里给出一份演示代码
<!DOCTYPE html><html>
<head>
<title></title>
</head>
<body>
<div id="d">
<div id="loading">正在加载。。。</div>
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1494214281262&di=ef0111cb95c5477f2dfc94acad9185dd&imgtype=0&src=http%3A%2F%2Fh5.86.cc%2Fwalls%2F20141217%2F1440x900_23b73a6904487a6.jpg">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1494214281262&di=d9369e8911c7ad7f74ca4427bdbfed51&imgtype=0&src=http%3A%2F%2Fpic10.nipic.com%2F20100929%2F4308872_150108084472_2.jpg">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1494214281262&di=87878630fa4786df3cdf8b09d8ec0d61&imgtype=0&src=http%3A%2F%2Ftupian.enterdesk.com%2F2013%2Fmxy%2F12%2F11%2F4%2F3.jpg">
</div>
<script type="text/javascript">
var div=document.getElementById("d")
function OnLoadElement(e){
var img= e.getElementsByTagName("img")
var num=0
if(img.length<=0){
return 1
}
for(var i=0i<img.lengthi++){
(function(j){
if(!img[j].complete){
img[j].onload=function(){
num++
console.log("已经加载图片:"+num+"/"+img.length)
if(num==img.length){
document.getElementById("loading").style.display="none"
console.log("内容加载完成")
}
}
}else{
num++
console.log("已经加载图片:"+num+"/"+img.length)
if(num==img.length){
document.getElementById("loading").style.display="none"
console.log("内容加载完成")
}
}
})(i)
}
}
OnLoadElement(div)
</script>
</body>
</html>
该演示在div内容加载完成了过后将正在加载隐藏了
控制台显示的内容