playwright中定位元素的方法

简介: playwright中定位元素的方法

playwright中定位元素的方法

1. page.$(selector)

该方法接受一个 CSS 选择器作为参数,并返回与选择器匹配的第一个元素。如果不存在匹配的元素,则返回 null。该方法常常用于选取指定 ID 或 class 的元素。

image.png

注意,该方法会根据 DOM 树中元素出现的顺序进行匹配,因此如果选择器可以匹配到多个元素,只会返回第一个匹配的元素。

通常情况下,page.$ 方法可以和其他方法一起使用,以实现更复杂的元素操作。

2. page.$$(selector)

该方法接受一个 CSS 选择器作为参数,并返回一个包含所有与选择器匹配的元素的数组。如果不存在匹配的元素,则返回空数组。

image.png

注意,该方法返回的数组中的元素顺序与它们在 DOM 树中出现的顺序相同。

3. page.locator(selector)

该方法创建一个 Locator 对象,可以用于更复杂的元素定位操作。该方法接受一个 CSS 选择器或 XPath 表达式作为参数,并返回一个 Locator 对象。

以下是使用 Locator 对象的示例:

image.png

由于 Locator 对象只是创建定位器的语法糖,所以它支持所有定位元素的方法和操作。

4. page.waitForSelector(selector[, options])

该方法等待指定的 CSS 选择器匹配的元素出现在页面上。该方法接受一个 CSS 选择器作为参数,以及可选的 options 参数,返回一个 Promise,该 Promise 会在元素出现或者超时之后 resolve。

 

以下是使用 page.waitForSelector 方法的示例:

image.png

options 参数可以包含以下项:

· visible:一个布尔值,指示元素是否必须可见。默认为 false

· hidden:一个布尔值,指示元素是否必须隐藏。默认为 false

· timeout:等待超时时间(以毫秒为单位)。默认为 30 秒。

该方法适用于需要等待特定元素出现的场景,如在页面刷新后等待加载完成的元素。

5. page.waitForFunction(pageFunction[, options[, ...args]])

该方法使用指定的匿名函数或字符串表达式进行定位,并返回一个 Promise,该 Promise 在函数返回 true 或者超时时 resolve。

 

以下是使用 page.waitForFunction 方法的示例:

image.png

options 参数可以包含以下项:

· polling:检查函数的间隔时间(以毫秒为单位)。默认为 1 秒。

· timeout:等待超时时间(以毫秒为单位)。默认为 30 秒。

该方法适用于需要等待复杂或动态生成的元素出现的场景,如等待 AJAX 请求完成后显示的元素。

总结

在 Playwright 中,有多种方式可以选择和定位元素,每种方式都可以使用 CSS 选择器或 XPath 表达式进行选择,使开发者可以根据自己的需求和场景进行选择。

 

目录
相关文章
|
开发工具 git
Playwright系列(6):如何集成到GitHub
Playwright系列(6):如何集成到GitHub
490 0
Playwright系列(6):如何集成到GitHub
|
10月前
|
Web App开发 开发框架 .NET
Playwright 自动化测试系列(6)| 第三阶段:测试框架集成​指南:参数化测试 + 多浏览器并行执行
Pytest 与 Playwright 集成可提升自动化测试效率,支持参数化测试、多浏览器并行执行及统一报告生成。通过数据驱动、Fixture 管理和并行优化,显著增强测试覆盖率与执行速度,适用于复杂 Web 应用测试场景。
|
9月前
|
自然语言处理 前端开发 测试技术
Playwright初学指南 (2):全面解析元素定位策略
本文深入解析Playwright革命性的元素定位体系,详解八大核心定位策略(语义化角色、文本内容、标签属性等)及其适用场景,提供动态元素处理方案和调试技巧。通过定位策略性能对比和企业级最佳实践,帮助开发者构建健壮、可维护的自动化测试脚本,有效解决75%的Web自动化测试失败问题。
|
7月前
|
人工智能 自然语言处理 JavaScript
Playwright MCP在UI回归测试中的实战:构建AI自主测试智能体
Playwright MCP结合AI智能体,革新UI回归测试:通过自然语言驱动浏览器操作,降低脚本编写门槛,提升测试效率与覆盖范围。借助快照解析、智能定位与Jira等工具集成,实现从需求描述到自动化执行的闭环,推动测试迈向智能化、民主化新阶段。
|
机器学习/深度学习 人工智能
ObjectMover:港大联合Adobe打造图像编辑黑科技,移动物体光影自动匹配
香港大学与Adobe联合研发的ObjectMover模型,通过视频生成先验迁移技术,实现图像中物体的自然移动、删除和插入,自动保持光影一致性。
410 21
ObjectMover:港大联合Adobe打造图像编辑黑科技,移动物体光影自动匹配
|
自然语言处理 资源调度 前端开发
前端大模型入门(四):不同文本分割器对比和效果展示-教你如何根据场景选择合适的长文本分割方式
本文详细介绍了五种Langchain文本分割器:`CharacterTextSplitter`、`RecursiveCharacterTextSplitter`、`TokenTextSplitter`、`MarkdownTextSplitter` 和 `LatexTextSplitter`,从原理、优缺点及适用场景等方面进行了对比分析,旨在帮助开发者选择最适合当前需求的文本分割工具,提高大模型应用的处理效率和效果。
3060 1
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
23198 31
|
前端开发 测试技术 开发者
精通Playwright的元素定位和CSS技巧
精通Playwright的元素定位和CSS技巧
1178 0
|
缓存 弹性计算 运维
网络管理利器:掌握常用的CMD命令
本文介绍了常用的网络CMD命令及其用法,包括`ping`、`ipconfig`、`tracert`、`nslookup`、`netstat`、`route`、`telnet`、`ftp`、`netsh`、`arp`、`nbtstat`、`hostname`、`systeminfo`、`ipconfig /flushdns`和`tasklist`。这些命令在日常的网络管理和故障排查中非常实用,帮助你轻松进行网络诊断、配置和监控。
1851 1