let isLoaded = false;
let myOnLoadCallBack = function(){
isLoaded = true;
//my stuff here
}
document.addEventListener("DOMContentLoaded", myOnLoadCallBack());
document.addEventListener('readystatechange', (event) => {
if (document.readyState === 'complete' && !isLoaded) {
myOnLoadCallBack();
}
);
使用了 DOMContentLoaded 事件侦听器,这是在构建 DOM 树但尚未加载任何其他资源(即样式表、图像等)时触发的。如果在 HTML 文档中找到任何 script 标记,DOMContentLoaded 也会等待加载这些脚本。) L8 H+ B' k# s
如果样式后面有脚本标记,在加载样式时就会出现问题。出现这种情况时,如果脚本需要修改样式,则在脚本之前加载样式。 3 ?( [; n. C9 d7 t. V! A. M IE 8 及更低版本不支持 DOMContentLoaded。如果你不得不支持 IE 8,应该用 document.readyState。5 B- i8 L M+ s: c ]
以下是不同的状态: 2 Y1 x) T) T7 B% u
5) $(…).empty() 3 E% Q8 y. x% ]7 [! D 清空或清除 DOM 元素。你可能会认为只需要将 innerHTML 属性赋给一个空字符串就行了。但这只做了一半,想一想如果目标元素还有子 DOM 元素会发生什么?我们会做到这一点,它也很简单。首先从清除现有元素的内容开始。1 O* [! H# e: ]- [6 f
var contentEl = document.getElementById("empty-content");
contentEl.innerHtml = "";
while(contentEl.firstChild){
contentEl.removeChild(contentEl.firstChild);
}
用 while 循环进行迭代,直到没有子项要删除为止。. M1 n7 o) a' e( E; I p3 d 6) $(…).Attr(name) " X. [& z4 G* h" e3 D% h 获取现有 DOM 元素的属性(attribute)值,或设置属性。要记住重要一点是:并非所有 DOM 元素都有相同的属性。例如复选框与按钮(按钮不具有 checked 属性)。从获取复选框的 checked 属性开始。 L2 b: z5 G( F
var toggleFunction = function(){...}
if (toggleBtn.removeEventListener) { // For all major browsers, except IE 8 and earlier
toggleBtn.removeEventListener("click", toggleFunction);
} else if (toggleBtn.detachEvent) { // For IE 8 and earlier versions
toggleBtn.detachEvent("click", toggleFunction)
}
总结- `2 H: q! i }' X% M
如果你一直在使用库和 JavaScript 框架,那么很容易忽略一些实现的简单性。但最重要的是,你也忽略了对 DOM 的一些核心工作原理的基本理解。很好地理解 DOM 不仅可以帮你更好的设计应用,还可以解决调试上的问题。/ |( j. D7 V' f5 w( z1 ]$ I
这些只是我最常用的一些函数。现在我把它们分享给你,如果你想写出自己的函数,而不是在自己的程序中添加使软件体积增加的库的话。