您的位置:首页 > 其它

使用xpath的轴(Axis)进行元素定位

2015-11-11 18:51 399 查看
使用Xpath轴方式可依据在文档数中的元素的相对位置来进行定位,先找到一个相对好定位的元素,在根据与它相对位置来定位其他元素,可以解决一些元素难以定位的问题。今天学习了,写下笔记加深下印象

如家HTML页面:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>在此处插入标题</title>
</head>
<body>
<div id="div1">
<input alt="div1-input1" id="iv1-input1" value="" /> <a
href="http://www.baidu.com">test</a> <img alt="div1-img1" src="">
<input type="button" id="div1-button1" name="div1-button" />
</div>
<div id="div2">
<input alt="div2-input2" id="div2-input2" value="" /> <a
href="http://www.sogou.com">test</a> <img alt="div2-img2" src="">
</div>

</body>
</html>


 画出树状图如下所示:

 


Xpath轴关键字轴的定义说明定位表达式实例表达式解释
parent选取当前节点的父节点//img[@alt='div2-img2']/parent::div查找到alt属性为div2-img2的img元素,并基于图片找到其上一级的div元素
child选取当前节点的子节点//div[@id='div1']/child::img查找id为div1的div标签,基于当前div查找标签为img的子节点
ancestor选取当前节点的所有上层节点//img[@alt='div2-img2']/ancestor::div查找alt属性为div2-img2的图片,基于当前图片找到其上级的div页面元素
descendant选取当前节点所有下层节点//div[@id='div2']/descendant::img查找id属性为div2的div元素,在查找其下级所有节点中的img元素
following选取当前节点之后显示的所有节点//div[@id='div1']/following::img查找到ID属性为div1的div元素,并基于div的位置找到它后面节点中的img元素
following-sibling选取当前节点所有的平级节点//img[@alt='div1-img1']/following-sibling::input查找到alt属性为div1-img1的img页面元素,并基于img的位置找到后续节点中的input元素
preceding选取当前节点前面所有的节点//img[@alt='div2-img2']/preceding::div查找到alt属性为div2-img2的图片页面元素,并基于图片的位置找到它前面节点中的div元素
preceding-sibling选取当前节点前面所有平级的节点//img[@alt='div2-img2']/preceding-sibling::a[1]查找到alt属性值为div2-img2的图片元素,基于图片位置找到它前面同级节点的第二个链接页面元素
下面是例子:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: