Cypress 基础 - 元素的定位

简介: Cypress 基础 - 元素的定位

Cypress basics: Selecting elements

Selecting a single element

语法:

cy.get('.selector')

首先,让我们看看 .selector 部分的内容。 Cypress 通过查询 DOM 来选择元素。 如果您曾经玩过 CSS 或使用过 jQuery,或者如果您熟悉 JavaScript 中的 document.querySelector 命令,您可能已经熟悉此类选择器。 让我们看看这是什么意思。 作为一个例子,我们可以查看一个看起来像这样的页面:

7.png页面代码如下:

<h1>Shapes:</h1>
<div class="square"></div>
<div id="circle"></div>
<div shape="triangle"></div>

我们可以使用 h1 标签选择一个元素。 如果我们想选择我们的一个形状,我们可以使用类、id 或属性来选择单个元素。

cy
  .get('h1') // select by tag
  .get('.square') // select by class
  .get('#circle') // select by id
  .get('[shape="triangle"]'); // select by attribute

要按类选择元素,您需要使用 . 前缀并通过它选择一个元素,你应该在 id 前面加上#。 您可能会在页面上找到的最常见属性是输入的占位符,甚至是测试 ID,其中您的选择器以方括号开始和结束。 如果选择我们选择在我们的页面上多次找到的元素,例如我们的 div 元素,Cypress 将选择所有三个。

Select elements by filtering

这是一个比较有用的操作。

一旦你选择了多个元素(例如通过 .get(‘li’) 命令,它返回 7 个元素),你可以根据另一个选择器在这些元素中进行过滤。 下面的代码将只选择红色、绿色和蓝色,因为这些是原色并且它们有一个类 .primary。

cy
  .get('li')
  .filter('.primary') // select all elements with the class .primary

要做完全相反的事情,您可以使用 .not() 命令。 使用此命令,您将选择除红绿蓝之外的所有颜色。

cy
  .get('li')
  .not('.primary') // select all elements without the class .primary

Finding elements

您可以通过首先选择要在其中搜索的元素来指定选择器,然后向下查看 DOM 结构以找到您要查找的特定元素。

cy
  .get('.list')
  .find('.violet') // finds an element with class .violet inside .list element

如果您已经在使用属性来标记您的元素,这里有一个提示。 您可以创建一个自定义命令,该命令将通过例如选择您的元素 数据-cy 属性:

Cypress.Commands.add('getById', (input) => {
  cy
    .get(`[data-cy=${input}]`)
})

消费:

cy
  .getById('indigo')

下图是 SAP 电商云 Spartacus UI Cypress 的一个例子:

8.png

在使用 click 方法触发 continue button 点击事件之前,我们先得检查其是否处于可点击状态,即 disabled 属性必须为 null.


7.png

目录
相关文章
|
5月前
|
前端开发 JavaScript
cypress 如何定位元素?
cypress 如何定位元素?
150 0
cypress 如何定位元素?
|
11天前
|
数据采集 前端开发 测试技术
Selenium中定位元素的9种方法
在Selenium中,定位页面元素是自动化测试和网页爬虫的基础。常用的9种元素定位方法包括:ID、Name、Class Name、Tag Name、CSS Selector、XPath、Link Text、Partial Link Text,以及XPath和CSS选择器的组合使用。每种方法各有优劣,建议根据页面的具体情况和元素的属性选择最合适的方法,并使用显式等待确保元素可用。
54 5
|
3月前
|
前端开发
ElementPlus卡片如何能够一行呈四,黑马UI前端布局视频资料,element样式具体的细节无法修改,F12找到那个位置,可能在其他组件写了错误,找到那个位置,围绕着位置解决问题最快了,卡片下边
ElementPlus卡片如何能够一行呈四,黑马UI前端布局视频资料,element样式具体的细节无法修改,F12找到那个位置,可能在其他组件写了错误,找到那个位置,围绕着位置解决问题最快了,卡片下边
|
5月前
|
XML 数据格式
Xpath高阶定位技巧,轻松玩转App测试元素定位!
XPath是一种用于XML文档中节点定位的语言,支持逻辑运算符(and、or、not)、轴定位、谓词和内置函数。
81 0
|
5月前
|
前端开发 JavaScript 开发者
playwright中定位元素的方法
playwright中定位元素的方法
227 1
|
5月前
|
测试技术 Android开发 索引
XPath定位如何在App自动化测试中大显神威
本文介绍了如何在Appium中使用XPath进行自动化App测试。通过淘宝App实例,展示了XPath在定位元素上的应用,包括基础定位(如通过text、resource-id、class和content-desc属性),contains模糊定位,组合定位以及层级定位(如父、子、兄弟和祖元素定位)。XPath的灵活性和强大功能使得在Appium中高效地定位元素成为可能,从而提升移动应用的测试效率。
63 0
|
5月前
|
JavaScript
cypress 支持哪些元素操作?
cypress 支持哪些元素操作?
cypress 支持哪些元素操作?
|
11月前
|
JavaScript 测试技术 Python
WebUI自动化测试中隐藏的元素如何操作?三种元素等待方式如何理解?
WebUI自动化测试中隐藏的元素如何操作?三种元素等待方式如何理解?
73 0
|
JavaScript 前端开发
Cypress 基础 - 元素的定位
Cypress 基础 - 元素的定位
|
JavaScript 前端开发 程序员
761.【技术】Selenium元素可定位,但不可操作,原因有哪些?--chatGTP
761.【技术】Selenium元素可定位,但不可操作,原因有哪些?--chatGTP
247 0