【WEB自动化测试】-元素操作方法和元素等待

一、元素常用操作方法

  • click()          单击元素
  • send_keys(value)       模拟输入
  • clear()       清除文本

提示:在使用操作中,一般对于输入框元素,都要先执行清空,再执行输入,避免操作错误

    driver = webdriver.Chrome()
    driver.get("http://localhost/backend/page/login/login.html")
    username = driver.find_element(By.CSS_SELECTOR, 'input[placeholder="账号"]')
    username.clear()
    time.sleep(1)
    username.send_keys("zhangsan")
    time.sleep(1)
    password = driver.find_element(By.CSS_SELECTOR, 'div>input[type="password"]')
    password.clear()
    time.sleep(1)
    password.send_keys("123456")
    time.sleep(1)

    btn = driver.find_element(By.CSS_SELECTOR, 'div.el-form-item__content>button')
    btn.click()
    time.sleep(3)
    driver.quit()

二、元素等待

2.1 什么是元素等待?

概念:在定位页面元素时如果未找到,会在指定时间内一直等待的过程

2.2 为什么要设置元素等待?

1. 网络连接慢

2. 电脑配置低

3. 服务器处理请求慢 

2.3 元素等待类型

 1. 隐式等待

 2. 显式等待 

三、隐式等待

3.1 概念

定位元素时,如果能定位到元素则直接返回该元素。不触发等待;如果不能定位到该元素,则间隔一段时间后再去定位元素;如果在达到最大时长时还没有找到指定元素,则抛出元素不存在的异常NoSuchElementException.

3.2 方法 

方法:driver.implicitly_wait(timeout)

        (timeout,为等待最大时长,单位:秒)

说明:隐式等待为全局设置(只需要设置一次,就会作用于所有元素),一般生产上设置为30秒。在最大化方法maximize_window()之后调用。与maximize_window()一样是必须的调用方法。

注意隐式等待的缺点:当隐式等待被激活时,虽然目标元素已经出现了,但是还是会由于当前页面内的其他元素的未加载完成,而继续等待,进而增加代码的执行时长。

四、显式等待 

4.1 概念

定位指定元素,如果能定位到元素则直接返回该元素,不触发等待;如果不能定位到该元素,则间隔一段时间后再去定位元素;如果在达到最大时长时还没有找到指定元素,则抛出超时异常TimeoutException.

在Selenium中把显式等待的相关方法封装在WebDriverWait类中

4.2 实现方式

1. 导包 等待类 -->from selenium.webdriver.support.wait import WebDriverWait

2. WebDriverWait(driver, timeout, poll_frequency=POLL_FREQUENCY, ignored_exceptions=None)

        1)driver:浏览器驱动对象

        2)timeout:超时的时长,单位:秒

        3)poll_frequency:监测间隔时间,默认为0.5秒

3. 调用方法:until(method):直到...时

        1)method:函数名称,该函数用来实现对元素的对位

        2)一般使用匿名函数来实现:lambda x: x.find_element(By.CSS_SELECTOR, '[placeholder="账号"]')

4.  element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_id("someId"))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值