首先,比较原始(蠢)的方法
function isChildOf(child, parent) { if(child && parent) { let parentNode = child.parentNode; while(parentNode) { if(parent === parentNode) { return true; } parentNode = parentNode.parentNode; } } return false; }
这里 while 中判断其实在实际情况我们应该换成我们要搜寻的上限的 dom,例如 while(parentNode === document.body) 即可。
当然,能省一行代码绝不多写一个字母才是我们这群懒人所需求的。
parent.contains(child) // true | false
返回一个布尔值,判断当前 parent 下面是否包含 child,包含关系为开区间(及 parent === child 时也成立)。
原文地址:https://www.cnblogs.com/YMaster/p/9941128.html
时间: 2024-10-07 06:29:16