xpath定位:selenium和playwrightAnt Design / 表单类页面)

selenium

💗元素定位出多个结果处理(Ant Design / 表单类页面)

比如要选择供应商

元素如下

定位

复制代码

//label[normalize-space(text())='供应商']/ancestor::div[contains(@class,'ant-form-item-row')]//input[@placeholder='请选择']

出现多个结果

修改定位如下:

复制代码
//label[normalize-space()='供应商']/parent::div/following-sibling::div//span[contains(@class,'select-input')]//input

结果是唯一的

详细分析:

复制代码
//label[normalize-space()='供应商'] 
/parent::div 
/following-sibling::div 
//span[contains(@class,'select-input')]//input

因为"请选择"不是唯一的,而"供应商"是唯一的

1.定位label本身

复制代码
//label[normalize-space()='供应商']

2.parent::div----回到label所在列

复制代码
/parent::div

结构是这样的

复制代码
div (label 容器)
 └── label 供应商

3.following-sibling::div ------ 找右侧输入区域

复制代码
/following-sibling::div

4.精准找到 Select 的 input

复制代码
//span[contains(@class,'select-input')]//input

💗xpath万能模板(Ant Design / 表单类页面)

普通输入框

复制代码
//label[normalize-space()='字段名'] /parent::div /following-sibling::div //input

AntD 下拉框(Select)

复制代码
//label[normalize-space()='字段名'] /parent::div /following-sibling::div //span[contains(@class,'select-input')]//input

TextArea

复制代码
//label[normalize-space()='字段名'] /parent::div /following-sibling::div //textarea

Playwright

Ant Design / 表单类页面比selenium更方便

playwright定位优先级

从高到低

1️⃣ getByRole()

2️⃣ getByLabel()

3️⃣ getByText()

4️⃣ locator('css')

5️⃣ locator('xpath') ❌(最后兜底)

以上述供应商选择为例

getByRole()

复制代码
const supplierSelect = page.getByLabel('供应商');

• Playwright 会自动:

• 找 <label> 文本 = "供应商"

• 关联到右侧的可交互控件

• 不关心 DOM 多乱

• Ant Design 完全适配

选择供应商

复制代码
await page.getByLabel('供应商').click(); 
await page.getByRole('option', { name: '某某供应商' }).click();

✔ 优点:

• 不关心 dropdown 在 body 还是 portal

• 自动等待

• 语义清晰,可维护性极高

表单中 Select 的"标准 Playwright 写法"

复制代码
await page.getByLabel('供应商').click();
await page.getByRole('listbox').getByText('供应商名称').click();
相关推荐
我的xiaodoujiao7 小时前
API 接口自动化测试详细图文教程学习系列9--Requests模块
python·学习·测试工具·pytest
oi..8 小时前
《Web 安全入门|XSS 漏洞原理、CSP 策略与 HttpOnly 防护实践》
前端·网络·测试工具·安全·web安全·xss
代码的乐趣9 小时前
支持selenium的chrome driver更新到147.0.7727.56
chrome·python·selenium
我的xiaodoujiao9 小时前
API 接口自动化测试详细图文教程学习系列10--Requests模块2--举例说明
python·学习·测试工具·pytest
橘子编程10 小时前
软件测试全流程实战指南
java·功能测试·测试工具·junit·tomcat·压力测试·可用性测试
RunningBComeOn10 小时前
如何通过wireshark抓取802.11无线网络的数据包
网络·测试工具·wireshark
llilian_161 天前
选择北斗导航卫星信号模拟器注意事项总结 北斗导航卫星模拟器 北斗导航信号模拟器
功能测试·单片机·嵌入式硬件·测试工具·51单片机·硬件工程
小白学大数据2 天前
Selenium+Python 爬虫:动态加载头条问答爬取
爬虫·python·selenium
周杰伦的稻香2 天前
tcpdump
网络·测试工具·tcpdump
金玉满堂@bj2 天前
什么是静态测试?
测试工具