以下定位技术之间有什么区别?
element(by.id("id"));
element(by.css("#id"));
element(by.xpath("//*[@id='id']"));
browser.executeScript("return document.querySelector('#id');");
browser.executeScript("return document.getElementById('id');");
而且,从 性能角度来看 ,哪种方法是通过id定位元素的最快方法?
您的问题很难回答,肯定会给出一个结论性的答案。实际上,我很想将此问题标记为“太宽泛”,其他答案和评论也支持该问题。
以您的为例element(by.id("id"));。纵观Selenium来源, 大多数 驱动程序只是获取您提供的ID,然后将其传递给有线协议:
public WebElement findElementById(String using) { if (getW3CStandardComplianceLevel() == 0) { return findElement("id", using); } else { return findElementByCssSelector("#" + cssEscape(using)); } }
如您所知,每个浏览器供应商都在单独的二进制文件中实现自己的有线协议。随意深入编写代码,为您自己挖一个更深的洞。
对于其他不支持有线协议的浏览器,例如HtmlUnit,您将拥有以下内容:
public List<WebElement> findElementsById(String id) { return findElementsByXPath("//*[@id='" + id + "']"); }
然后他们解析可用的DOM。
至于您的表现问题,任何人给您的东西都是1)只是一种 感觉 ,或者2)纯净的BS!您已经从其他答案和评论中看到了。
要获得 真实 答案(由实际数据支持),要考虑的变量太多:
此外,由于用于构建该网站的框架的差异,您为Web应用程序/网页获得的任何结果都将最不适用于其他Web应用程序/网页。
底线是:如果您担心性能测试,那么Selenium是错误的答案。Selenium是一个功能测试库,经过优化可为您提供最佳的最终用户表示形式。性能是遥不可及的。
如果您的目标是使测试更快地运行,则可以花更多的时间在测试结构上:
但是我认为这与您最初提出的问题脱离了话题(有些人可能会建议“保证”)。