深入浅出xpath轴定位

在web自动化里面经常要用到定位,常用的八种定位方式中我最喜欢xpath定位,功能很强大。结合它里面的文本定位、模糊定位、逻辑定位等,基本能搞定所有的元素定位问题。

  今天要讨论的是xpath的另一种比较复杂的定位:轴定位。网上的关于轴定位的我翻了下,说得都不够详细 ,有的一笔带过,这着实苦恼了我许久。晚上研究了会,发现这玩意确实不好理解,特此记录一下,以防日后又忘了。。

  总共主要有八个轴关键字,parent,child,ancestor(祖先),descendant(后裔),following,following-sibling,preceding(前面的),preceding-sibling。具体含义如下:

 

  1. parent::div ——上层父节点,你那叫div的亲生爸爸,最多有一个;

  2. child::div ——下层所有子节点,你的所有亲儿子中叫div的;/child::div等价于/div

  3. ancestor::div ——上面所有直系节点,你亲生爸爸或者你亲爹或者你亲爹的爸爸中叫div的;

  4. descendant::div ——内部所有节点,你的后代中叫div的,你的所有儿子以及儿子的儿子,不包括你弟弟的后代;/descendant::div等价于//div

  5. following::div ——下节点,自你以下(排除自己及自己的后代)页面中所有节点叫div的;

  6. following-sibling::div ——同层下节点,你所有的亲弟弟中叫div的,不包括你侄子;

  7. preceding::div ——同层上节点,你所有的亲哥哥以及他们的后代中叫div的;

  8. preceding-sibling::div ——同层上节点,你所有的亲哥哥中叫div的;

 

 

注意他们之间有些微妙的区别,最好结合实际的元素定位例子亲自操作一下,这里以小米商城mi.com首页为例:

1、parent:

 

2、child:

 

 

3、ancestor:

 

4、descendant:

 

5、following:注意这个不包括自身,从同层下一节点开始,如果已经是该层最后,则从上一层的下一节点开始

 

6、following-sibling:

 

7、preceding:

 

 

8、preceding-sibling:

 

ok,就写到这,拜拜了~

posted @ 2019-10-08 23:34  天青色wy  阅读(10299)  评论(2编辑  收藏  举报