cypress 如何定位元素?

简介: cypress 如何定位元素?

大家好,我是阿萨。上一次 如何调试cypress脚本?讲解了debug 和pause 这2个关键字。通过暂停和调试,大家学会了如何调试脚本。肯定都想着多写一些脚本,锻炼下自己的能力呢。

今天阿萨就给大家讲解下如何定位元素。


一 cy.get获取元素


  1. 如何定位一个button?和css selector 有点类似。


cy.get('#query-btn').should('contain', 'Button')//类似jquery的方法cy.get('.query-btn').should('contain', 'Button')
cy.get('#querying .well>button:first').should('contain', 'Button')


2. 如何定位一个attribute data-test-id 是sarah的div?


cy.get('[data-test-id="Sarah"]').should('have.class', 'example')cy.get('[data-test-id="Sarah"]')  .invoke('attr', 'data-test-id')  .should('equal', 'test-example')
// 可以直接获取它对的css 属性cy.get('[data-test-id="Sarah"]')  .invoke('css', 'position')  .should('equal', 'static')



二 cy.contains() 获取元素方式


1. 如何获取一个列表里的某个元素?比如下图

image.png


 cy.get('.query-list')
  .contains('bananas').should('have.class', 'third')
 // 正则表达是
cy.get('.query-list')
  .contains(/^b\w+/).should('have.class', 'third')
 cy.get('.query-list')
  .contains('apples').should('have.class', 'first')
 // 把具体值传给contains
cy.get('#querying')
  .contains('ul', 'oranges')
  .should('have.class', 'query-list')
 cy.get('.query-button')
  .contains('Save Form')
  .should('have.class', 'btn')



三.cy.within()获取元素的方式。根据元素里面的placeholder 去定位元素。


比如下图:

image.png


cy.get('.query-form').within(() => {  cy.get('input:first').should('have.attr', 'placeholder', 'Email')  cy.get('input:last').should('have.attr', 'placeholder', 'Password')})



四.cy.root()找根元素。这个是查找相对的根元素,不是绝对的根元素。


image.png


 // 默认根是document
cy.root().should('match', 'html')
 cy.get('.query-ul').within(() => {
  // 在上图的例子里根元素说是ul dom 元素
  cy.root().should('have.class', 'query-ul')
})


五.查找元素的最佳实践。


 <button
  id="main"
class="btn btn-large"
  name="submission"
  role="button"
  data-cy="submit"
>
  Submit
</button>


HTML 中有一个这样的button。常见的button 的定位方法:

  1. cy.get('button').click()
  2. cy.get('.btn.btn-large').click()
  3. cy.get('#main').click()
  4. cy.get('[name="submission"]').click()
  5. cy.contains('Submit').click()
  6. cy.get('[data-cy="submit"]').click()


以上6种定位元素的方式里推荐使用顺序是6 >5>4>3>2>1.使用data-*属性 作为选择器提供上下文,并将它们与CSS或JS更改隔离开来。这个其实也不难理解。比如我们人去查找元素的时候就会先看Button的文本是submit. 所以就很好理解了。


六。定位元素或者操作元素注意事项


定位元素或者操作元素之前,我们必须确保满足以下条件。将元素滚动到视图中。确保元素没有被隐藏。确保元素没有被禁用。确保元素没有分离。确保元素不是只读的。确保元素没有动画。确保元素没有被覆盖。你学会了吗?如果觉得阿萨的内容对你有帮助,欢迎围观点赞。


相关文章
|
8月前
cypress 如何遍历元素?
cypress 如何遍历元素?
101 0
|
2月前
|
数据采集 前端开发 JavaScript
捕捉页面的关键元素:用CSS选择器与Puppeteer自动抓取
本文介绍了如何使用 Puppeteer 结合 CSS 选择器抓取动态网页中的关键元素,以亚航网站的特价机票信息为例,通过设置代理 IP、User-Agent 和 Cookie 等技术手段,有效提升爬虫策略,实现高效、稳定的爬取。
捕捉页面的关键元素:用CSS选择器与Puppeteer自动抓取
|
3月前
|
数据采集 前端开发 测试技术
Selenium中定位元素的9种方法
在Selenium中,定位页面元素是自动化测试和网页爬虫的基础。常用的9种元素定位方法包括:ID、Name、Class Name、Tag Name、CSS Selector、XPath、Link Text、Partial Link Text,以及XPath和CSS选择器的组合使用。每种方法各有优劣,建议根据页面的具体情况和元素的属性选择最合适的方法,并使用显式等待确保元素可用。
539 5
|
8月前
|
前端开发 JavaScript 开发者
playwright中定位元素的方法
playwright中定位元素的方法
289 1
|
Web App开发 前端开发 JavaScript
Selenium 如何定位 JavaScript 动态生成的页面元素
Selenium 是一个自动化测试工具,可以用来模拟浏览器的操作,如点击、输入、滚动等。但是有时候,我们需要定位的页面元素并不是一开始就存在的,而是由 JavaScript 动态生成的。这时候,如果我们直接用 Selenium 的 find_element 方法去定位元素,可能会出现找不到元素的错误,因为页面还没有加载完成。为了解决这个问题,我们需要使用一些特定的定位技巧,让 Selenium 等待元素出现后再进行操作。
563 0
|
前端开发 测试技术 开发者
selenium-元素的定位
selenium-元素的定位
|
JavaScript 前端开发 程序员
761.【技术】Selenium元素可定位,但不可操作,原因有哪些?--chatGTP
761.【技术】Selenium元素可定位,但不可操作,原因有哪些?--chatGTP
266 0
|
XML 前端开发 JavaScript
Selenium自动化用法详解【定位页面元素】
Selenium自动化用法详解【定位页面元素】
244 0
cypress 遍历元素的方法有哪些?
大家好,我是阿萨。昨天学习了cypress的元素操作方法。今天我们继续学习cypress的元素遍历方法。
332 0
cypress 遍历元素的方法有哪些?
|
XML JavaScript Java
appium定位-控件定位
客户端的页面通过 XML 来实现 UI 的布局,页面的 UI 布局作为一个树形结构,而树叶被定义为节点。这里的节点也就对应了要定位的元素