文章目录
- 前言
- 一、alert弹出框类型?
- 二、使用方法
- 1.alert用法
- 2.confirm用法
- 3.prompt用法
- 三、如何去掉自定义弹窗
- 总结
前言
在做自动化测试时,对于alert类型的弹出框如果不做处理,就无法对页面进行定位等下一步操作,那么alert类型的弹出框有哪些呢?相应的弹出框应该如何做处理呢?下面将一一介绍
提示:以下是本篇文章正文内容,下面案例可供参考
一、alert弹出框类型?
alert弹出框包含三种:
alert 提醒对话框
confirm 确认对话框
prompt 要求用户输入,然后返回结果的对话框
alert-alert弹出框示例:
alert-confirm弹出框示例:
alert-prompt弹出框示例:
二、使用方法
switch_to.alert 定位到alert/confirm/prompt
text 返回alert/confirm/prompt 中的文字信息。
accept 点击确认按钮。
dismiss 点击取消按钮,如果有的话。
send_keys 输入值,这个alert\confirm 没有对话框就不能用了,不然会报错。
基本思路:先利用方法switch_to.alert定位到alert(alert/confirm/prompt)弹出框(注意:对于三种类型的alert弹出框定位到弹出框的方法都一样),再进行相应的处理(确认/取消/输入值)
1.alert用法
代码如下(示例):
submit1 = driver.find_element_by_name("Submit")
submit1.click()
# 1.处理alert弹出框(alert)
alert = driver.switch_to.alert
sleep(3)
# 1.1获取弹出框文本值
alert_content = alert.text
print(alert_content)
# 1.2点击确认按钮
alert.accept()
2.confirm用法
代码如下(示例):
# 2.处理alert弹出框(confirm)
submit2 = driver.find_element_by_name("Submit2")
submit2.click()
confirm = driver.switch_to.alert
sleep(2)
print(confirm.text)
# confirm.accept() # 点击“确认”按钮
confirm.dismiss() # 点击“取消”按钮
sleep(2)
confirm.accept()
3.prompt用法
代码如下(示例):
# 3.处理alert弹出框(prompt)
submit3 = driver.find_element_by_name("Submit3")
submit3.click()
prompt = driver.switch_to.alert
prompt.send_keys("大力水手吃菠菜") # 这里输入框中看不到输入的文字
sleep(2)
prompt.accept()
sleep(2)
prompt.accept()
三、如何去掉自定义弹窗
对于自己定义的弹窗,如果不想每次测试网页前,通过模拟点击等操作去除弹窗,有一个比较“暴力”的方法–直接通过js代码块,将对应的弹窗显示属性设置为none,这样弹窗就不会出现啦
下面通过一个小例子演示如何去除自定义弹窗,要求:去掉图中的对话框弹窗
在F12模式下,定位到该对话框,将其样式的display属性值设置为none
代码如下(示例):
# 利用js代码块去除自定义弹窗
js1 = 'document.getElementById('div_company_mini').style.display='none';'# div_company_mini为弹窗对应的id
driver.execute_script(js1)
实现结果如下图:
这里多提一嘴,如何在F12模式下查看js代码(去除弹窗是否生效)是否正确?有两个方法:
(1)F12模式下,在控制台输入js语句,回车,看弹窗是否去除
(2)F12模式下直接修改源代码源代码如下图:
修改方法如下图:
总结
小白一枚,如有错误,还请指出,谢谢~