自动化测试学习(六)-selenium定位元素之CSS选择器详细用法

目录

1.通过class属性定位

2.通过id属性定位

3.通过标签名定位

4.其他方法定位


   CSS是一种语言,它可以比较灵活的选择控件的任意属性,一般情况下比Xpath快,下面我们详细介绍CSS的用法。CSS常见语法如下表所示: 

选择器示例描述
.class.s_ipt选择class="s_ipt"的所有元素
#id#kw选择id="kw"的所有元素
**选择所有元素
elementinput选择所有<input>元素
element>elementspan>input选择<span>下的所有<input>元素
element+elementdiv+a选择同一级中<div>元素之后的所有<a>元素
[attribute=value][type=text]

选择type="text"的所有元素

还是以百度输入框和搜索按钮为例: 

1.通过class属性定位

driver.find_element(By.CSS_SELECTOR,'.s_ipt')

2.通过id属性定位

driver.find_element(By.CSS_SELECTOR,'#kw')

3.通过标签名定位

# 因为input标签不是唯一的,所以无法成功定位
driver.find_element(By.CSS_SELECTOR,'input')

标签名相同的概率非常大,所以通过标签名定位元素很难找到想要的元素,因此我们可以通过zu组合方法来定位。

4.其他方法定位

(1)通过父子关系定位,用‘>’表示。

driver.find_element(By.CSS_SELECTOR,'form>span>input')

(2)通过属性定位,[attribute=value]即[属性名=属性值]。

driver.find_element(By.CSS_SELECTOR,'[name="wd"]')

(3)组合定位。

①tag name+class

driver.find_element(By.CSS_SELECTOR,'input.s_ipt')

②tag name+id

driver.find_element(By.CSS_SELECTOR,'input#kw')

③tag name+attribute

driver.find_element(By.CSS_SELECTOR,'input[name="wd"]')

Xpath与CSS类似功能的对比如下表所示:

定位方式XpathCSS
tag name//inputinput
id//input[@id='kw']input#kw
class//input[@class='s_ipt']input.s_ipt
属性//input[@type='text']input[type=text]
子元素

//span/input

span>input

总结:

        通过对比可以看出来,CSS语法更加简洁,可以满足日常定位元素需求,所以更推荐大家使用。


下一篇:自动化测试学习(七)-正则表达式,你真的会用吗

  • 8
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿哈哈~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值