javascript判断dom是否加载完毕
首先要明确两个概念 1.window.onload:页面加载完毕,页面内所有组件(图片等)都可用。 2.dom 加载:指文档对象模型加载完毕,要先于window.onload事件。 可以看出,当页面包含大量组件(特别是图片)的情形下,以上两种加载的时间相隔将会很长,这时判断dom何时加载完成就显得特别重要 页面的一些组件(css,image,flash)不会导致页面的DOM未构建完成。只有JS会阻塞页面的DOM节点的构建 function init() { // 如果该函数被调用多次,直接返回 if (arguments.callee.done) return; // arguments.callee.done = true; // 清除对safari设置的定时器 if (_timer) clearInterval(_timer); alert(document.getElementById(“test”).id); }; // firefox和opera9.0 if (document.addEventListener) { document.addEventListener(“DOMContentLoaded”, init, false); } //ie document.write(“<script id=__ie_onload defer src=javascript:void(0)></script>”); var script = document.getElementById(“__ie_onload”); script.onreadystatechange = function() { if (this.readyState == “complete”) { init(); // call the onload handler } }; //Safari if (/WebKit/i.test(navigator.userAgent)) { // sniff var _timer = setInterval(function() { if (/loaded|complete/.test(document.readyState)) { init(); // call the onload handler } }, 10); } //其它浏览器直接用window.onload事件 window.onload = init; 来源:http://www.wellpeter.com/?p=162 (编辑:老爷爷站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 科创板|致远互联挂牌上市 开盘报75元较发行价上涨51.85%
- Uber:将为全球提供1000万次免费乘车和餐饮配送服务
- FinOps Foundation加入Linux Foundation以确定最佳的云财务
- 苹果推迟使用MicroLED:Apple Watch 6继续由京东方供应OLED
- 美国增强现实初创公司Magic Leap宣布融资3.5亿美元
- 北京自动驾驶路测总里程突破200万公里,今年前10个月里程数
- 高通总裁安蒙:5G将有助于社会经济变得更具弹性和竞争力
- CoinMarketCap更新交易所排名计算方式 币安目前排名第一
- 京东:2019年度活跃购买用户数3.62亿 同比增长18.6%
- 华为官方推特直接开骂@apple负责人称:被盗号了