JavaScript 判断 DOM 何时加载完毕

处理HTML DOM文档存在一个难题是,JavaScript可以在DOM完全加载之前执行,这会给你的代码引发不少的潜在问题。浏览器的渲染和操作顺序大致如下列表:

  • HTML解析完毕
  • 外部脚本和样式表加载完毕
  • 脚本在文档内解析并执行
  • HTML DOM完全构造起来
  • 图片和外部内容加载
  • 网页完成加载

 

在网页头部并且从外部文件加载的脚本会在HTML真正构造之前执行。如前所述,这是个至关重要的问题,因为这两处执行的脚本并不能访问还不存在的DOM。幸好,我们还有若干的补救方法。

 

目前,最常用的级数是完全等待整个页面加载完毕才执行DOM操作。这种技术只需利用window对象的load事件来绑定一个函数,页面加载完毕即可触发。

 

addEvent(window, "load", function(){
    // do something
});


最简单的操作却是最慢的。在加载过程的顺序列表中,你会注意到页面的加载完毕与否完全被最后一步所掌控。这就是说,如果页面有很多的图片、视频等,用户可能得登上一段时间JavaScript才执行。

另一种级数可用以监听 DOM 加载状态,可能是最复杂的(从实现角度来看),但也是最有效地。

这项技术在不堵塞浏览器加载的情况下尽可能快地检查 HTML DOM文档是否已经加载了执行所必须得属性。以下是检查HTML DOM是否可用的几个要点:

  1. document: 你需要知道DOM文档是否已经加载。若能足够快地检查,运气好的话你会看到undefined。
  2. document.getElementsByTagName和document.getElementById:频繁使用document.getElementsByTagName和document.getElementById函数检查文档,当存在这些函数则表明DOM已经加载完毕。
  3. document.body: 作为额外补充,检查元素是否已经完全加载。理论上前一个检查应该已经能做出判断,但我发现有些情况下还是不够。

使用这些检查就足够判断DOM是否可用了(“足够”在此表示可能会有一定毫秒级的时间差)。这个方法几乎没有瑕疵。单独使用前述检查,脚本应该可以在现代浏览器中运行得相对良好。但是,最近(2008年?)Firefox实现了缓存改进,使得window加载事件实际上可以在脚本能检查到DOM是否可用之前触发。为了能发挥这个优势,我同时为window加载事件附加检查,以期能获得更快的执行速度。


最后,domReady函数集合了所有需要在DOM可用时就执行的函数的引用。一旦DOM被认为是可用的,就调用这些引用并按顺序一一执行。

// 监听 DOM 是否可用的函数
function domReady(f) {
    // 假如DOM已经加载,马山执行函数
    if(domReady.done) return f();

    // 假如我们已经增加了一个函数
    if(domReady.timer) {
        // 把它假如待执行函数清单中
        domReady.ready.push(f);
    } else {
        // 为页面加载完毕绑定一个事件,以防它最先完成。
        addEvent(window, "load", isDOMReady);
        // 初始化执行函数的数组
        domReady.ready = [f];
        // 尽可能快的检查DOM是否已可用
        domReady.timer = setInterval(isDOMReady, 13);
    }
}

// 检查 DOM 是否已可操作
function isDOMReady() {
    // 如果我们能判断出DOM已可能,忽略
    if(domReady.done) return false;

    // 检查若干函数和元素是否可能
    if(document && document.getElementsByTagName && document.getElementById && document.body) {
        // 如果可用,我们停止检查
        clearInterval(domReady.timer);
        domReady.timer = null;

        // 执行所有正在等待的函数
        for(var i = 0; i < domReady.ready.length; i++) {
            domReady.ready[i]();
            // 记录我们在此已经完成
            domReady.ready = null;
            domReady.done = true;
        }
    }
}

 

现在我们来看看在HTML文档中是如何执行的。假设已经将domReady函数写到一个名为domready.js的外部文件中

<html>
    <head>
        <title> Testing DOM Loading</title>
        <script src="domready.js"></script>
        <script>
            domReady(function(){
                alert("The DOM is loaded!");
                // do something
            });
        </script>
    </head>
    <body>
        <h1>Testing DOM Loading</h1>
        <!-- 这里是大量的HTML -->
    </body>
</html>

 内容摘自《精通JavaScript》

转载于:https://www.cnblogs.com/ninofocus/archive/2012/11/11/2764640.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值