Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select)

2024-05-16 08:28

本文主要是介绍Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更多关于Selenium的知识请访问CSND论坛“兰亭序咖啡”的专栏:专栏《Selenium 从入门到精通》

​​


1. 前言

这是我的《Selenium从入门到精通》专栏的第11篇文章,前面花了很多时间在元素的定位上。不管是爬虫和自动化,找到元素后,我们通常还会需要和这么网页元素做一些交互,比如:

  • 点击“注册”按钮
  • 在“账号文本框”中输入账号
  • 清空文本内容
  • 提交“注册表单”
  • 在“证件类型”下拉列表中选择身份证

Selenium WebDriver提供了一系列简洁而强大的API,可以通过它们直接操纵页面上的各类元素,从而模拟用户交互行为。和上面的需求基本对应:

  • click 模拟用户点击元素的动作
  • send keys 向可输入的文本元素发送文本数据
  • clear 清除文本元素中的内容
  • submit 模拟提交表单操作
  • select 处理下拉选择框

本文将系统性地介绍Selenium中对Web元素进行操作的五大核心命令,并通过Java代码示例展示其具体应用。

2. 五大核心命令

我们用Java和Junit来测试Selenium。测试结构:

@Slf4j
public class InteractionTest {private WebDriver driver = null;@BeforeEachpublic void setup(){driver = new ChromeDriver();}@AfterEachpublic void tearDown(){driver.quit();}@Testpublic void test() throws InterruptedException {// 测试代码写在这里!}
}

2.1 sendKeys() 输入文本

我们可以通过 sendKeys 可输入的文本元素(如输入框、可编辑区域)发送文本数据。

@Test
public void testSendKeys() throws InterruptedException {driver.get("https://www.baidu.com");WebElement searchBtn = driver.findElement(By.id("kw"));searchBtn.sendKeys("兰亭序咖啡的专栏");TimeUnit.SECONDS.sleep(5);
}

可以看到“兰亭序咖啡”被自动填写到用户名文本框。

2.2 click() 点击

click 可以模拟用户点击元素的动作,几乎适用于页面上的任何可点击元素,如按钮、链接等。

@Test
public void testClick() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");WebElement verifyCodeSend = driver.findElement(By.id("TANGRAM__PSP_4__verifyCodeSend"));verifyCodeSend.click();TimeUnit.SECONDS.sleep(5);
}

点击“获取验证码” 按钮

2.3 clear() 清空文本

clear() 用来清除文本元素中的内容,同样只适用于可输入的文本元素。

@Test
public void testClick() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");WebElement userName = driver.findElement(By.name("userName"));userName.sendKeys("兰亭序咖啡的专栏");TimeUnit.SECONDS.sleep(5);userName.clear();TimeUnit.SECONDS.sleep(5);
}

文本框先是被设置,然后等待几秒后被清空

2.4 submit() 提交表单

submit 用来 模拟提交表单操作,通常用于表单元素,当点击表单内的提交按钮时,会触发此操作。

@Test
public void testSubmit() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");driver.findElement(By.name("userName")).sendKeys("abab233214567");driver.findElement(By.id("TANGRAM__PSP_4__form")).submit();TimeUnit.SECONDS.sleep(5);
}

尝试提交表单(不经过点击“登录”按钮)

因为一些必填字段没有填写,所以提交不成功

2.5 select() 选择下拉列表

select() 专门用于处理下拉选择框(<select>元素),提供了丰富的选项选择方法,如按值、索引或文本选择。

@Test
public void testSelect() throws InterruptedException {driver.get("https://www.runoob.com/try/try.php?filename=tryhtml_option");WebElement dropdown = driver.findElement(By.xpath("//select"));Select select = new Select(dropdown);select.selectByIndex(3);select.selectByValue("saab");select.selectByVisibleText("Volvo");TimeUnit.SECONDS.sleep(5);
}

可以通过三种方式选中特定的下拉列表选项!

3. 高级交互的特点

其实除了本文要介绍的五大核心交互外,Selenium 还提供了更底层的Action类也可以实现类似的功能。那么它们有什么区别呢?

因为这五个核心交互命令是高级的交互,也就是模拟人类的操作,所以,它们有两个特别的点:

  • 如果元素不在页面的可视范围,它会滚动页面到元素的位置,然后再操作。
  • 做这些操作前,Selenium 会确保元素是可交互的。(interactable)。如果元素不可交互,会抛出ElementNotInteractableException的异常!

下面几种情况会抛出ElementNotInteractableException异常:

  • 元素不在可视范围内——比如被其它元素挡住了(比如loading框)
  • 元素没有显示——比如隐藏的元素
  • 不可点击——比如页面还在加载中,或者按钮是disabled状态

4. 结束语

本文介绍了五种常用的高级交互,通过Selenium提供的这些特性,我们可以用Selenium实现更丰富的功能。关注兰亭序咖啡,一起学习更多Selenium的知识。

这篇关于Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994380

相关文章

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

如何使用Ansible实现CI/CD流水线的自动化

如何使用Ansible实现CI/CD流水线的自动化 持续集成(CI)和持续交付(CD)是现代软件开发过程中的核心实践,它们帮助团队更快地交付高质量的软件。Ansible,作为一个强大的自动化工具,可以在CI/CD流水线中发挥关键作用。本文将详细介绍如何使用Ansible实现CI/CD流水线的自动化,包括设计流水线的结构、配置管理、自动化测试、部署、以及集成Ansible与CI/CD工具(如Jen

easyui 验证下拉菜单select

validatebox.js中添加以下方法: selectRequired: {validator: function (value) {if (value == "" || value.indexOf('请选择') >= 0 || value.indexOf('全部') >= 0) {return false;}else {return true;}},message: '该下拉框为必选项'}

uniapp设置微信小程序的交互反馈

链接:uni.showToast(OBJECT) | uni-app官网 (dcloud.net.cn) 设置操作成功的弹窗: title是我们弹窗提示的文字 showToast是我们在加载的时候进入就会弹出的提示。 2.设置失败的提示窗口和标签 icon:'error'是设置我们失败的logo 设置的文字上限是7个文字,如果需要设置的提示文字过长就需要设置icon并给

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到