我有一个要用作书签的 html 元素,但我无法修改 html 文档。我想将此元素存储在其他地方并将其保留为 Xpath 查询。
有没有办法将 html 元素转换为指向它的 xpath 查询?
我有一个要用作书签的 html 元素,但我无法修改 html 文档。我想将此元素存储在其他地方并将其保留为 Xpath 查询。
有没有办法将 html 元素转换为指向它的 xpath 查询?
这是一个来自类似问题的方法来接收这样的 DOM-Path:
function createXPathFromElement(elm) {
var allNodes = document.getElementsByTagName('*');
for (segs = []; elm && elm.nodeType == 1; elm = elm.parentNode)
{
if (elm.hasAttribute('id')) {
var uniqueIdCount = 0;
for (var n=0;n < allNodes.length;n++) {
if (allNodes[n].hasAttribute('id') && allNodes[n].id == elm.id) uniqueIdCount++;
if (uniqueIdCount > 1) break;
};
if ( uniqueIdCount == 1) {
segs.unshift('id("' + elm.getAttribute('id') + '")');
return segs.join('/');
} else {
segs.unshift(elm.localName.toLowerCase() + '[@id="' + elm.getAttribute('id') + '"]');
}
} else if (elm.hasAttribute('class')) {
segs.unshift(elm.localName.toLowerCase() + '[@class="' + elm.getAttribute('class') + '"]');
} else {
for (i = 1, sib = elm.previousSibling; sib; sib = sib.previousSibling) {
if (sib.localName == elm.localName) i++; };
segs.unshift(elm.localName.toLowerCase() + '[' + i + ']');
};
};
return segs.length ? '/' + segs.join('/') : null;
};
还有一个用于测试的小提琴(路径显示在控制台中)。