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();
相关推荐
se-tester1 天前
JMeter、Postman 和 SoapUI 在做接口测试上的优势和缺点
测试工具·jmeter·接口测试·postman·soapui
xixi09241 天前
selenium IDE——command
selenium·测试工具
xixi09241 天前
selenium IDE安装使用教程
ide·selenium·测试工具
Wpa.wk2 天前
har文件转为接口自动化测试用例
运维·测试工具·自动化·测试用例·接口自动化
Wpa.wk2 天前
ubuntu22桌面版安装
经验分享·测试工具
uyeonashi2 天前
自动化测试问卷考试系统测试报告
功能测试·selenium·github
007张三丰2 天前
软件测试专栏(6/20):Selenium从0到1实战指南:元素定位、等待机制与框架封装
selenium·测试工具
测试老哥2 天前
如何使用Postman做接口测试?
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
安全不再安全2 天前
某驱动任意读漏洞分析 - 可用于游戏内存数据读取
c语言·测试工具·安全·游戏·网络安全