我正在尝试在这里翻译 Javascript 函数。
这将产生一个给定 org.w3c.dom.DOMElement 的基本 xpath 字符串:/html/body/p[3]/a
getElementXpath
如果我注释掉getElementIdx()
函数和条件,效果很好。问题似乎位于getElementIdx()
,但我看不出我做错了什么,下面的 Java 代码与 Javascript 版本几乎相同。
会发生什么是返回一个空字符串!我尝试打印出getElementXpath
函数内部的路径,但没有任何效果。预期的输出是一个基本的 xpath 字符串!
更新:
public static String getElementXpath(DOMElement elt){
String path = "";
for (; elt != null && elt.ELEMENT_NODE == elt.getNodeType(); elt = (DOMElement) elt.getParentNode()){
path = "test";
System.out.println(path); //this prints out fine.
}
System.out.println(path); //nothing is printed!
return path;
}
为什么不在 for 循环之外打印路径???
public static void main(String[] args){
DOMDocument domDocument = (DOMDocument) browser.getDocument();
DOMElement currentElement = (DOMElement) domDocument.getElementFromId("uniqueLink");
System.out.println(getElementXpath(currentElement));
}
public static String getElementXpath(DOMElement elt){
String path = "";
for (; elt != null && elt.ELEMENT_NODE == elt.getNodeType(); elt = (DOMElement) elt.getParentNode()){
int idx = getElementIdx(elt);
String xname = elt.getTagName();
if (idx > 1) xname += "[" + idx + "]";
path = "/" + xname + path;
}
System.out.println(path);
return path;
}
public static int getElementIdx(DOMElement elt) {
int count = 1;
for (DOMElement sib = (DOMElement) elt.getPreviousSibling(); sib != null; sib = (DOMElement) sib.getPreviousSibling())
{
if(sib.ELEMENT_NODE == sib.getNodeType() && sib.getTagName().equals(elt.getTagName())){
count++;
}
}
return count;
}