Cypress 做 e2e 测试,如何在获得某个 checkbox 后先判断它是否被 check 然后再更改它的状态?

比如如果这个 checkbox 已经被 check 了,就不做操作,否则将它 check。

我们假设这个 checkbox 的 data-testid 属性是 VendorCodeCheckbox-0-test-id。Cypress 的代码如下:

javascript 复制代码
cy.getByTestId('VendorCodeCheckbox-0-test-id')
  .shadow()
  .find('[role=checkbox]')
  .then(checkbox => {
    if (checkbox.get().at(0).ariaChecked !== 'true') {
      checkbox.click()
    }
  })

注意,对于不同的前端框架,寻找组件的逻辑可能不同。

相关推荐
前端炒粉2 小时前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
巧克力芋泥包3 小时前
前端使用阿里云图形验证码;并且与安卓进行交互
android·前端·阿里云
G***E3164 小时前
前端GraphQLAPI
前端
lumi.4 小时前
Vue + Element Plus 实现AI文档解析与问答功能(含详细注释+核心逻辑解析)
前端·javascript·vue.js·人工智能
z***I3944 小时前
VueGraphQLAPI
前端
S***t7145 小时前
Vue面试经验
javascript·vue.js·面试
粉末的沉淀6 小时前
css:制作带边框的气泡框
前端·javascript·css
p***h6437 小时前
JavaScript在Node.js中的异步编程
开发语言·javascript·node.js
N***73857 小时前
Vue网络编程详解
前端·javascript·vue.js
e***71677 小时前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端