子元素与后代元素
I had the need to find out of an element I got via a click event was a descendant of a particular parent element.
我需要找出通过click事件获得的元素是特定父元素的后代。
I assigned an id
to that parent, and I checked if the clicked element belonged to its child elements using this loop:
我为该父对象分配了一个id
,并使用此循环检查了clicked元素是否属于其子元素:
const isDescendant = (el, parentId) => {
let isChild = false
if (el.id === parentId) { //is this the element itself?
isChild = true
}
while (el = el.parentNode) {
if (el.id == parentId) {
isChild = true
}
}
return isChild
}
document.addEventListener('click', event => {
const parentId = 'mycontainer'
if (isDescendant(event.target, parentId)) {
//it is a descendant, handle this case here
} else {
//it's not a descendant, handle this case here
}
})
In the while loop we use the assignment operator =
to iterate until there’s no parent node anymore, in that case el.parentNode
returns null
and the while loop ends.
在while循环中,我们使用赋值运算符=
进行迭代,直到没有父节点为止,在这种情况下, el.parentNode
返回null
,而while循环结束。
It’s a way to go “up” in the elements tree until it finishes.
这是在元素树中“向上”直至完成的一种方法。
翻译自: https://flaviocopes.com/how-to-check-element-descendant/
子元素与后代元素