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();
相关推荐
武汉禹力自动化科技14 小时前
Carlo Gavazzi Dupline 测试工具 GTU8 深度解析:现场总线调试与诊断的核心利器
测试工具·佳乐现场总线·gtu8
qq_4279403414 小时前
java-UI自动化selenium+TestNG
java·selenium·自动化
程序员小远15 小时前
单元测试知识详解
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
半个俗人16 小时前
2.postman断言
测试工具·postman
Wpa.wk17 小时前
自动化测试 - Playwrigh简单介绍+基础使用
经验分享·测试工具·playwright
Love Song残响17 小时前
Wireshark实战:从抓包到网络诊断
网络·测试工具·wireshark
爆更小哇17 小时前
jmeter插件下载+创建梯度线程组+命令生成性能测试报告
测试工具·jmeter·自动化
Saniffer_SH17 小时前
【高清视频】AI服务器调试利器:PCIe功耗分析设备 Quarch PAM 深度解析
网络·人工智能·驱动开发·嵌入式硬件·测试工具·计算机外设·压力测试
PM老周1 天前
ONES和Jira对比测评:研发管理工具选型该看功能、部署还是长期成本?
测试工具·团队开发·个人开发·软件需求·结对编程
测试狗科研平台1 天前
测试GO与京东方开展柔性OLED失效分析技术交流会
科技·测试工具·材料工程