selenium大部分的方法参数都是
java.lang.String locator,假如我们想传入xptah表达式,可以在表达式的开头加上"xpath=",也可以不加.如下面的两个效果是一样的.
selenium.getAttribute("//tr/input/@type") === selenium.getAttribute("xpath=//tr/input/@type")
selenium中有一个比较特别而非常有用的方法
java.lang.Number getXpathCount(java.lang.String xpath)
通过此方法我们可以得到所有匹配xpath的数量,调用此方法,传入的表达式就不能以"xpath="
开头.
另外需要知道的是:当xpath表达式匹配到的内容有多个时,seleium默认的是取第一个,假如,我们想
自己指定第几个,可以用"xpath=(xpath表达式)[n]"来获取,例如:
selenium.getText("//table[@id=‘order‘]//td[@contains(text(),‘删除‘)]");
在id为order的table下匹配第一个包含删除的td.
selenium.getText("xpath=(//table[@id=‘order‘]//td[@contains(text(),‘删除‘)])[2]");
匹配第二个包含删除的td.
在调试xpath的时候,我们可以下个firefox的xpath插件,这样可以在页面上通过右键开启xpath插件.
然后随时可以检验xpath所能匹配的内容,非常方便.假如通过插件
测试的xpath表达式可以匹配
到预期的内容,但是放到selenium中跑却拿不到,那么最有可能出现的问题是:在你调用seleium方法
时,传入的xpath表达式可能多加了或者是少加了"xpath=".
以下为几个常用的xpath:
1.selenium.getAttribute("//tr/input/@type")
2.selenium.isElementPresent("//span[@id=‘submit‘ and @class=‘size:12‘]");
3.selenium.isElementPresent("//tr[contains(@sytle,‘display:none‘)]");
4.selenium.isElementPresent("//*[contains(name(),‘a‘)]"); //这个等价于 //a
5.selenium.isElementPresent("//tr[contains(text(),‘金钱‘)]");
English » | | | | | | | | |
Text-to-speech function is limited to 100 characters
Selenium中常用的xpath
原文:http://www.blogjava.net/qileilove/archive/2014/12/23/421653.html