首页 > web前端 > js教程 > 正文

如何在不依赖框架的情况下确定 DOM 准备情况?

Susan Sarandon
发布: 2024-10-20 11:52:02
原创
463 人浏览过

How Can I Determine DOM Readiness Without Relying on Frameworks?

Document.isReady:DOM 就绪检测的本机解决方案

依赖于 Prototype 和 jQuery 等框架来管理 window.onload 事件可能不会总是令人向往。本文探讨了确定 DOM 就绪情况的替代方法,特别是通过使用 document.isReady。

查询 Document.isReady

对于具有稳定事件 API 的现代浏览器, DOMContentLoaded 事件提供了处理 DOM 就绪事件的强大方法。像下面这样的实现提供了一个简单而高效的解决方案:

<code class="javascript">function fireOnReady() { /* ... */ }
if (document.readyState === 'complete') {
    fireOnReady();
} else {
    document.addEventListener("DOMContentLoaded", fireOnReady);
}</code>
登录后复制

jQuery 的 $.isReady 属性

jQuery 提供了一个未记录的属性 $.isReady,它反映了DOM 内部就绪状态。利用此属性可以进行简洁的检查:

<code class="javascript">if($.isReady) {
    // DOM is ready
} else {
    // DOM is not yet ready
}</code>
登录后复制

值得注意的是,此属性仍未记录在案,并且无法保证其在未来 jQuery 版本中的可用性。谨慎使用它,并为升级时可能发生的变化做好准备。

自定义 DOM 就绪代码段

为了更广泛的浏览器兼容性,可以使用自定义 DOM 就绪代码段。受到 Dustin Diaz 方法的启发,它使用正则表达式检查 document.readyState:

<code class="javascript">if( !/in/.test(document.readyState) ) {
    // document is ready
} else {
    // document is NOT ready
}</code>
登录后复制

此方法依赖于“in”子字符串存在于“loading”和“interactive”ready 中的事实状态但不是“完整”状态。

以上是如何在不依赖框架的情况下确定 DOM 准备情况?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!