playwright+python 等待元素至指定状态

playwright+python 等待元素到某种状态


当进行UI自动化测试时,保证测试的稳定性至关重要。其中一个关键方面是正确地定位和操作网页中的元素。在网页中,元素可能处于不同的状态,有些可能在页面加载完成之前不在DOM中,需要某些操作后才会出现,而其他元素可能一直存在于DOM中,但最初处于隐藏状态,需要通过操作才能使其可见。

如果在执行脚本时没有考虑到元素的状态,很可能导致脚本执行失败。为了保证自动化测试的稳定性,我们需要确保在执行操作之前,所需的元素已经达到了指定状态。

下面我将介绍三种常用的元素等待方式:wait_for(), wait_for_selector(), 和 wait_for_element_state(),以及三者之间的优劣势。

wait_for()

wait_for() 是先定位元素,再等待元素满足指定状态。

如果元素已满足条件,则立即返回。否则,它会等待直到超时时间到达为止。
该方法接受两个关键字参数:
timeout:指定最大等待时间(以毫秒为单位)。默认为 30000(30秒),但可以更改。
state:指定要等待的状态。默认为 ‘visible’。可以是 ‘attached’、‘detached’、‘hidden’ 或 ‘visible’ 中的一个。

下面是一个示例代码:

# 等待元素出现在DOM中
page.locator(selector).wait_for(state="attached")
# 等待从DOM中移除
page.locator(selector).wait_for(state="detached")
# 等待元素隐藏
page.locator(selector).wait_for(state="hidden")
# 等待元素可见
page.locator(selector).wait_for(state="visible")

wait_for_selector()

wait_for_selector(),等待元素满足指定状态。这个方法的参数和用法与 wait_for() 类似,但是针对选择器而不是定位器。如果没有传 state 参数,默认情况下是"visible"(等待元素可见)。
当选择器指定的元素满足 state 选项时,返回。如果等待的是 hidden 或 detached,则返回 null。
如果在调用该方法时,选择器已经满足条件,则立即返回。
如果选择器在 timeout 毫秒内不满足条件,则函数会抛出异常。

下面是一个示例代码:

# 等待元素出现在DOM中
page.wait_for_selector(selector, state="attached")
# 等待从DOM中移除
page.wait_for_selector(selector, state="detached")
# 等待元素隐藏
page.wait_for_selector(selector, state="hidden")
# 等待元素可见
page.wait_for_selector(selector, state="visible")

wait_for_element_state( )

wait_for_element_state()与wait_for_selector() 连用,先使用 wait_for_selector() 来定位元素,然后再使用 wait_for_element_state() 来等待该元素达到特定的状态。

下面是一个示例代码:

# 等待元素不可用
page.wait_for_selector(selector).wait_for_element_state(state="disabled")
# 等待元素隐藏
page.wait_for_selector(selector).wait_for_element_state(state="hidden")
# 等待元素可用
page.wait_for_selector(selector).wait_for_element_state(state="enabled")
# 等待元素可编辑
page.wait_for_selector(selector).wait_for_element_state(state="editable")
# 等待元素稳定(已经加载完全且不再有任何动态变化)
page.wait_for_selector(selector).wait_for_element_state(state="stable")

总结:
wait_for() 方法:
使用方式:
通过 page.locator(‘定位元素’).wait_for() 调用。
返回值:
返回的是 None。
使用限制:
由于返回值是 None,所以后续不能继续对元素进行操作。

wait_for_selector() 方法:
使用方式:
通过 page.wait_for_selector(“定位方法”) 调用。
返回值:
返回的是 Locator 对象,可以继续对元素进行操作。
使用优势:
由于返回的是 Locator 对象,因此可以在等待期间对元素进行其他操作,如获取元素属性、执行点击等操作。

wait_for_selector().wait_for_element_state() 方法:
使用方式:
首先通过 page.wait_for_selector(selector) 来等待选择器所定位的元素。
然后在返回的元素上调用 wait_for_element_state() 方法。
返回值:
返回的是 None,表示等待完成。如果在等待期间元素达到了指定状态,则不会返回任何其他对象。
使用优势:
通过组合使用这两个方法,可以确保在对元素进行操作之前,元素已经完全加载且处于期望的状态。

  • 20
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

blues_C

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

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

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

打赏作者

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

抵扣说明:

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

余额充值