考虑以下标记
<div id = "parent">
<a id = "child1" href = "#">1</a>
<a id = "child2" href = "#">2</a>
<a id = "child3" href = "#">3</a>
<a id = "child4" href = "#">4</a>
</div>
我需要通过其位置(X 和 d Y 坐标)获取父级内部的子级。当我使用 var element = document.elementFromPoint(x, y); 时,它返回父元素。有没有办法获取子元素?
最佳答案
You could use document.elementsFromPoint
instead.
它返回一个数组。
const elementsAtPoint = document.elementsFromPoint(x, y)
const numberOfElementsAtPoint = elementsAtPoint.length
嵌套最深的元素位于数组的第一个元素,而最外层的元素位于最后一个。您可以通过 id 找到父元素,并返回数组中位于其之前的元素。
像这样详细的一步一步:
const elementsAtPoint = document.elementsFromPoint(x, y);
const elementIds = elementsAtPoint.map(element => element.id);
const parentIndex = elementIds.indexOf("parent");
const childIndex = parentIndex - 1;
const childElement = elementsAtPoint[childIndex];
我在控制台做了一些测试,我认为这应该可行。您必须处理找不到元素的情况。
我可能会将其重写为一个函数:
function getChildAtPoint(parentId, x, y){
const elementsAtPoint = document.elementsFromPoint(x, y);
const elementIds = elementsAtPoint.map(element => element.id);
const parentIndex = elementIds.indexOf(parentId);
// If we can't find element with parentId, or it is the first
// in the array we found nothing.
if( parentIndex < 1 ){ return; };
const childIndex = parentIndex - 1;
const childElement = elementsAtPoint[childIndex];
return childElement;
}
关于javascript - 通过坐标获取子元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27188091/