tag name
tag name 为标签名定位,使用网页元素的标签名如a, div, input, span 等
。
但是有一个问题,常见的标签名比如
当然普通的模拟操作是不大有用,这个重复性实在太高了。但是在某些特殊情况下,比如需要使用 body、html、head 这些元素的时候, tag name 就有用了。
另外批量处理某些标签的时候,也可以使用 tag name。
在代码中的写法如下:
driver.find_element_by_tag_name("body")
在 console 中验证唯一性的代码为:
document.getElementsByTagName('body')
link text 与 partial link text
link 定位与前面几种定位方法不同,是一种特殊的定位方式,专门用来定位文本链接的,也就是 <a>
标签。
链接文本在 HTML 页面上普遍存在,只要是 <a>
标签,都可以使用 link text 定位,既精确又高效。
一般一个页面不会出现两个文本相同的 <a>
标签,因为如果出现,会让用户疑惑
我们试试用这种方法来定位百度右上角的链接:
代码如下:
driver.find_element_by_link_text("新闻")
driver.find_element_by_link_text("地图")
注意:
这种方式有一个缺点,就是在这些链接文本中有空格或其他字符,在页面或者开发者工具中不太容易注意到,那么这种情况就会导致定位失败。因此使用时最好从开发者工具中去复制文本。
Partial link text 是 link text 定位的一种补充,比如上面提到的可能有空格或其他字符,或者链接地址特别长的时候,或者链接中有部分文本是变化的。
那么可以取链接中的一部分来进行定位,当然这种方法的精确性就不是那么容易保证了。
比如上图百度首页中的hao123
,我们可以写为:
driver.find_element_by_partial_link_text("hao")
验证 link text 是否唯一的方法只有借助 JQuery 和 xpath 了:
// link text
$x('//a[string()="这里输链接文本"]')
// partial link text
$x('//a[contains(string(), "这里输链接文本")]')
注意,这不是特别精确的验证。