当 Selenium 的 click() /send_keys()等方法失效时:JavaScript 在 UI 自动化测试中的神奇用法

引言

在使用 Selenium 进行 Web UI 自动化测试时,我们通常依赖 Selenium 提供的原生方法(如 click()send_keys() 等)来操作页面元素。然而,在某些复杂场景下,这些方法可能会失效。例如:

  • 元素被遮挡或隐藏。
  • 页面加载延迟导致元素无法正常交互。
  • 某些特殊的动态行为无法通过 Selenium 原生方法触发。

这时,JavaScript 就成为了我们的“救星”。通过 driver.execute_script(),我们可以直接操作 DOM,绕过这些问题。本文将深入探讨 JavaScript 在 UI 自动化测试中的各种用法,并结合实际案例展示其强大功能。


一、Selenium 原生方法失效的常见场景
  1. 元素被遮挡

    • 当一个按钮被其他元素(如弹窗、广告等)遮挡时,Selenium 的 click() 方法会抛出异常。
  2. 元素不可见

    • 某些情况下,元素虽然存在但不可见(display: nonevisibility: hidden),Selenium 无法直接与其交互。
  3. 动态加载延迟

    • 页面上的某些元素可能需要等待一段时间才能完全加载并变得可交互,而 Selenium 的默认超时设置可能不足以处理这种情况。
  4. 禁用状态的元素

    • 如果某个按钮或输入框被设置为 disabled,Selenium 无法直接对其进行操作。

二、JavaScript 在 UI 自动化测试中的用法
1. 点击被遮挡或不可见的元素

当 Selenium 的 click() 方法失效时,可以通过 JavaScript 直接触发元素的点击事件:

# 使用 JavaScript 点击元素
element = driver.find_element(By.ID, "myButton")
driver.execute_script("arguments[0].click();", element)

这种方法可以绕过遮挡或可见性限制,确保点击操作成功。

2. 滚动到指定元素

如果目标元素不在当前视口内,Selenium 的操作可能会失败。此时,可以使用 JavaScript 滚动到目标元素的位置:

# 滚动到元素位置
element = driver.find_element(By.ID, "targetElement")
driver.execute_script("arguments[0].scrollIntoView(true);", element)
3. 修改元素属性

有时我们需要修改元素的属性,例如移除 disabled 属性或更改 value

# 移除 disabled 属性
element = driver.find_element(By.ID, "submitButton")
driver.execute_script("arguments[0].removeAttribute('disabled');", element)# 修改输入框的值
input_element = driver.find_element(By.ID, "username")
driver.execute_script("arguments[0].value = 'new_username';", input_element)
4. 触发事件

某些交互(如 focusblurchange 等)可能无法通过 Selenium 原生方法触发,可以使用 JavaScript 来实现:

# 触发 focus 事件
element = driver.find_element(By.ID, "inputField")
driver.execute_script("arguments[0].focus();", element)# 触发 blur 事件
driver.execute_script("arguments[0].blur();", element)
5. 动态添加或删除元素

在某些特殊场景下,我们可能需要动态创建或删除页面上的元素:

# 动态创建新元素
driver.execute_script("""var newElement = document.createElement('div');newElement.innerHTML = 'Hello, World!';document.body.appendChild(newElement);
""")# 删除指定元素
element = driver.find_element(By.ID, "toBeRemoved")
driver.execute_script("arguments[0].parentNode.removeChild(arguments[0]);", element)
6. 获取页面信息

JavaScript 可以帮助我们获取页面的标题、URL 或性能数据:

# 获取页面标题
title = driver.execute_script("return document.title;")
print(f"Page Title: {title}")# 获取当前 URL
url = driver.execute_script("return window.location.href;")
print(f"Current URL: {url}")
7. 处理浏览器窗口

调整浏览器窗口大小或最大化窗口也可以通过 JavaScript 实现:

# 调整窗口大小
driver.execute_script("window.resizeTo(800, 600);")# 最大化窗口
driver.execute_script("window.moveTo(0, 0); window.resizeTo(screen.width, screen.height);")

三、JavaScript 的优势与注意事项
优势:
  1. 灵活性高:可以直接操作 DOM,绕过许多 Selenium 原生方法的限制。
  2. 功能强大:能够完成复杂的操作,如修改属性、触发事件、动态添加元素等。
  3. 兼容性强:适用于大多数现代浏览器。
注意事项:
  1. 优先使用 Selenium 原生方法:只有在原生方法无法满足需求时,才考虑使用 JavaScript。
  2. 避免滥用:过度依赖 JavaScript 可能导致测试脚本与实际用户行为不符。
  3. 注意兼容性:不同浏览器对 JavaScript 的支持可能存在差异,需进行充分测试。

希望本文能为你在自动化测试中使用 JavaScript 提供一些启发。如果你有更多关于自动化测试的经验或问题,欢迎在评论区分享!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/35689.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

观察者模式详解:用 Qt 信号与槽机制深入理解

引言 你是否曾遇到这样的需求:一个对象的状态发生变化后,希望通知其他对象进行相应的更新?比如: 新闻订阅系统:当新闻发布后,所有订阅者都会收到通知。股票行情推送:股价变化时,所…

流量分析实践

下载附件使用wireshark打开,发现数据包非常多,一共有1万多条数据,我们点击分析来看一下协议分级 然后我们再来看一下会话,看有哪些ip地址, 我们通过会话结合大部分的流量发现,172.17.0.1一直在请求172.17.0…

新手村:混淆矩阵

新手村:混淆矩阵 一、前置条件 知识点要求学习资源分类模型基础理解分类任务(如二分类、多分类)和常见分类算法(如逻辑回归、决策树)。《Hands-On Machine Learning with Scikit-Learn》Python基础熟悉变量、循环、函…

MYSQL库的操作

目录 一、创建数据库 二、字符集和校验规则 1、查看系统默认字符集以及校验规则 2、查看系统支持的所有字符集以及字符集校验规则 3、指定字符集以及校验规则来创建数据库 4、校验规则对数据库的影响 三、操纵数据库 1、查看数据库 2、修改数据库 3、删除数据库 4、数…

Next App Router(下)

五、loading 新增 app/loading.tsx 页面 const Loading () > {return <div>Loading...</div>; }; export default Loading;修改 app/page.tsx页面 /** 假设为一个获取数字的api */ const fetch_getNumber async (): Promise<number> > {return ne…

【JAVA】】深入浅出了解cookie、session、jwt

文章目录 前言一、首先了解http的cookie是什么&#xff1f;Cookie 属性及其含义1. NameValue2. Expires3. Max-Age4. Domain5. Path6. Secure7. HttpOnly8. SameSite示例 Cookie 分类1. Session Cookies2. Persistent Cookies3. First-Party Cookies4. Third-Party Cookies 二、…

【css酷炫效果】纯CSS实现粒子旋转动画

【css酷炫效果】纯CSS实现粒子旋转动画 缘创作背景html结构css样式完整代码效果图 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u011561335/90492008 缘 创作随缘&#xff0c;不定时更新。 创作背景 刚看到csdn出活动了&…

C++Lambda表达式

Lambda表达式 什么是Lambda表达式 ​ C11的颁布让C丰富了起来&#xff0c;任何一本介绍C11的书籍&#xff0c;都不可能跳过这一个点——Lambda表达式。人们经常称Lambda表达式是一个语法糖&#xff0c;说明这是一个”没有没事&#xff0c;有了更好“的一种语法表达&#xff0…

每天五分钟深度学习框架pytorch:基于pytorch搭建循环神经网络RNN

本文重点 我们前面介绍了循环神经网络RNN,主要分析了它的维度信息,其实它的维度信息是最重要的,一旦我们把维度弄清楚了,一起就很简单了,本文我们正式的来学习一下,如何使用pytorch搭建循环神经网络RNN。 RNN的搭建 在pytorch中我们使用nn.RNN()就可以创建出RNN神经网络…

el-table树形表格合并相同的值

el-table树形表格合并相同的值 el-table树形表格合并相同的值让Ai进行优化后的代码 el-table树形表格合并相同的值 <style lang"scss" scoped> .tableBox {/deep/ &.el-table th:first-child,/deep/ &.el-table td:first-child {padding-left: 0;} } …

2025年3月19日 十二生肖 今日运势

小运播报&#xff1a;2025年3月19日&#xff0c;星期三&#xff0c;农历二月二十 &#xff08;乙巳年己卯月丁亥日&#xff09;&#xff0c;法定工作日。 红榜生肖&#xff1a;兔、虎、羊 需要注意&#xff1a;猪、猴、蛇 喜神方位&#xff1a;正南方 财神方位&#xff1a;…

Git——分布式版本控制工具使用教程

本文主要介绍两种版本控制工具——SVN和Git的概念&#xff0c;接着会讲到Git的安装&#xff0c;Git常用的命令&#xff0c;以及怎么在Vscode中使用Git。帮助新手小白快速上手Git。 1. SVN和Git介绍 1.1 SVN 集中式版本控制工具&#xff0c;版本库是集中存放在中央服务器的&am…

QT5.15.2加载pdf为QGraphicsScene的背景

5.15.2使用pdf 必须要安装QT源码&#xff0c;可以看到编译器lib目录已经有pdf相关的lib文件&#xff0c;d是debug 1.找到源码目录&#xff1a;D:\soft\QT\5.15.2\Src\qtwebengine\include 复制这两个文件夹到编译器的包含目录中:D:\soft\QT\5.15.2\msvc2019_64\include 2.找…

【H2O2 | 软件开发】前端深拷贝的实现

目录 前言 开篇语 准备工作 正文 概述 JSON方法 递归 其他 结束语 前言 开篇语 本系列为短篇&#xff0c;每次讲述少量知识点&#xff0c;无需一次性灌输太多的新知识点。该主题文章主要是围绕前端、全栈开发相关面试常见问题撰写的&#xff0c;希望对诸位有所帮助。…

Docker - 切换源 (Linux / macOS)

文章目录 Linux 系统macOS 系统 Linux 系统 修改配置文件&#xff1a;/etc/docker/daemon.json "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn","https://hub-mirror.c.163.com"]验证是否修改成功&#xff1a; docker info重启 …

hcia复习

一、网络设备 1、交换机&#xff1a;&#xff08;1&#xff09;提供MAC地址表&#xff0c;转发数据&#xff1b; &#xff08;2&#xff09;每个接口是一个独立的冲突域&#xff1b; &#xff08;3&#xff09;凡是连在交换机上的所有设备都处于同一广播域&#xff08;网络&am…

opencv初步学习——图像处理3

这一部分我们将学习opencv中对图像大小进行调整的基本操作&#xff0c;以及掩模操作&#xff0c;我们直接进入正言 一、cv2.resize( )函数 1-1、组成与构造 该函数的作用就算用来帮助我们实现对图像大小的处理&#xff0c;具体的组成与构造如下&#xff1a; cv2.resize(src , …

[LevelDB]关于LevelDB存储架构到底怎么设计的?

本文内容组织形式 LevelDB 存储架构重要特点总体概括LevelDB中内存模型MemTableMemTable的数据结构背景&#xff1a;SkipListSkiplist的数据结构 Skiplist的数据访问细节 SkipList的核心方法Node细节源代码 MemTable的数据加速方式Iterator 的核心方法 MemTable 的读取&写入…

【存储中间件】Redis核心技术与实战(四):Redis高并发高可用(Redis集群 Smart客户端、集群原理)

文章目录 Redis集群Smart客户端smart客户端原理ASK 重定向集群下的Jedis客户端Hash tags 集群原理节点通信通信流程Gossip 消息节点选择 故障转移故障发现主观下线客观下线 故障恢复资格检查准备选举时间发起选举选举投票替换主节点 故障转移时间 集群不可用判定集群读写分离 个…

【接口耗时】⭐️自定义拦截器实现接口耗时统计

&#x1f4a5;&#x1f4a5;✈️✈️欢迎阅读本文章❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;本篇文章阅读大约耗时三分钟。 ⛳️motto&#xff1a;不积跬步、无以千里 &#x1f4cb;&#x1f4cb;&#x1f4cb;本文目录如下&#xff1a;&#x1f381;&#x1f381;&a…