搜索同级时使用 CSS 选择器而不是 XPath 定位器

2023-06-15前端开发问题
2

本文介绍了搜索同级时使用 CSS 选择器而不是 XPath 定位器的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

目前,我有以下页面对象字段:

Currently, I have the following page object fields:

this.filterTeamDropdown = $("filter-item-edit .dropdown button");
this.teams = this.filterTeamDropdown.all(by.xpath("following-sibling::ul//li[contains(@class, 'dropdown-list-item')]"));

有没有办法替换 teams 字段的 XPath 定位器并使用 CSS 选择器?

Is there a way to replace the XPath locator for the teams field and have a CSS selector instead?

它的动机来自 样式指南 和 建议不要使用 XPaths.

The motivation for it is coming from the Style Guide and the recommendation not to use XPaths.

据我了解,不可能有一个 CSS 选择器从上下文中的当前元素开始转到下一个兄弟姐妹.但是,有其他选择吗?

From what I understand, it is impossible to have a CSS selector to go to the next sibling starting from current element in the context. But, are there any alternatives?

推荐答案

对任何事情说永不"是愚蠢的.我强烈支持 CSS 选择器,因为通过 id 定位元素、CSS 选择器、几乎任何东西……都比 XPath 快.但是...同时我们说的是几毫秒的差异.

Saying NEVER to anything is silly. I strongly favor CSS selectors because locating element by id, CSS selector, just about anything... is faster than XPath. But... at the same time we're talking a few ms of difference.

XPath 可以做一些其他定位器方法无法做到的事情.想到的一个例子是通过包含的元素文本查找元素(A 除外).除此之外,当 ID 不起作用时,我通常会坚持使用 CSS 选择器.

There are some things that XPath can do that no other locator method can. One example that comes to mind is finding an element (other than A) by contained element text. Other than that I generally stick to CSS selectors when ID doesn't work.

我非常不喜欢很多人在 SO 上的定位器策略,因为 XPath 似乎是查找元素的首选方式,以至于它很愚蠢.我见过人们只寻找一个 id 并使用 XPath.我认为部分原因在于您可以轻松获得 XPath,右键单击检查器中的元素并复制 XPath 并粘贴到代码中.我相信您知道,问题在于有时(很多时候?)这会导致 XPath 非常脆弱,但有些/很多人不知道更好.

I strongly dislike a lot of people's locator strategies on SO because XPath seems to be the goto way to find elements to the point where it's silly. I've seen people looking for nothing but an id and using XPath. I think part of it is the ease of which you can obtain an XPath, right click on element in inspector and copy XPath and paste in code. The problem with that, as I'm sure you know, is that sometimes (many times?) that results in a very brittle XPath but some/many people don't know any better.

说了这么多,我会告诉你 W3C CSS 选择器参考,也许你能找到你要找的东西.那里有一些兄弟组合器,但我没有你的 HTML,所以我不知道它们中的哪一个(如果有的话)可以工作.

All that said, I'll point you to the W3C CSS Selector reference and maybe you can find what you are looking for. There are some sibling combinators in there but I don't have your HTML so I don't know which, if any, of them would work.

https://www.w3.org/TR/selectors/#selectors

https://www.w3.org/TR/selectors/#相邻兄弟组合器

我刚刚阅读了您问题下方的一些评论,发现您已经了解 + 组合器.是否有某些原因您不能将初始定位器 CSS 与 XPath 转换的字符串一起使用?我不知道这是否有效/可用,但在将 XPath 转换为 CSS 选择器后,我已经组合了您在代码中提供的两个定位器.

I just read some of the comments below your question and see that you already knew about the + combinator. Is there some reason you can't reuse your initial locator CSS with the XPath converted string? I don't know if this is even valid/usable but I've combined the two locators you provided in your code after converting the XPath to a CSS selector.

filter-item-edit .dropdown button + ul li.dropdown-list-item

这篇关于搜索同级时使用 CSS 选择器而不是 XPath 定位器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

js删除数组中指定元素的5种方法
在JavaScript中,我们有多种方法可以删除数组中的指定元素。以下给出了5种常见的方法并提供了相应的代码示例: 1.使用splice()方法: let array = [0, 1, 2, 3, 4, 5];let index = array.indexOf(2);if (index -1) { array.splice(index, 1);}// array = [0,...
2024-11-22 前端开发问题
182

JavaScript小数运算出现多位的解决办法
在开发JS过程中,会经常遇到两个小数相运算的情况,但是运算结果却与预期不同,调试一下发现计算结果竟然有那么长一串尾巴。如下图所示: 产生原因: JavaScript对小数运算会先转成二进制,运算完毕再转回十进制,过程中会有丢失,不过不是所有的小数间运算会...
2024-10-18 前端开发问题
301

JavaScript(js)文件字符串中丢失"\"斜线的解决方法
问题描述: 在javascript中引用js代码,然后导致反斜杠丢失,发现字符串中的所有\信息丢失。比如在js中引用input type=text onkeyup=value=value.replace(/[^\d]/g,) ,结果导致正则表达式中的\丢失。 问题原因: 该字符串含有\,javascript对字符串进行了转...
2024-10-17 前端开发问题
437

layui中table列表 增加属性 edit="date",不生效怎么办?
如果你想在 layui 的 table 列表中增加 edit=date 属性但不生效,可能是以下问题导致的: 1. 缺少日期组件的初始化 如果想在表格中使用日期组件,需要在页面中引入 layui 的日期组件,并初始化: script type="text/javascript" src="/layui/layui.js"/scrip...
2024-06-11 前端开发问题
455

Rails/Javascript:如何将 rails 变量注入(非常)简单的 javascript
Rails/Javascript: How to inject rails variables into (very) simple javascript(Rails/Javascript:如何将 rails 变量注入(非常)简单的 javascript)...
2024-04-20 前端开发问题
5

CoffeeScript 总是以匿名函数返回
CoffeeScript always returns in anonymous function(CoffeeScript 总是以匿名函数返回)...
2024-04-20 前端开发问题
13