-
Notifications
You must be signed in to change notification settings - Fork 5
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Propose several CSS Selector style shorthands (first-child, last-child, etc.) #19
Comments
Orthogonality is always a good design principle. If you want the first or last node on the child axis, then you might equally want the first or last node on any other axis, e.g. following-sibling or ancestor. (Of course we have parent as a special case for ancestor::*[1]; but let's not use that as a precedent).
If we don't like child::*[1]/self::name (and we don't), then we could allow
child::[1]name
or
child::[1]text()
or more generally
AxisStep ::= (ReverseA <https://www.w3.org/TR/xpath-31/#doc-xpath31-ReverseStep>xis | ForwardA <https://www.w3.org/TR/xpath-31/#doc-xpath31-ForwardStep>xis) PredicateList <https://www.w3.org/TR/xpath-31/#doc-xpath31-PredicateList> NodeTest
to indicate that the predicate is applied before the node-test, without any loss of orthogonality.
It looks unambiguous to me: "::" followed by "[" can't mean anything else.
Michael Kay
… On 6 Apr 2020, at 17:51, Reece H. Dunn ***@***.***> wrote:
I've found myself wanting to write XPath expressions equivalent or similar to the CSS E:first-child selector. The two use cases I have so far is:
first child element is a given element -- child::*[1]/self::element-name;
first child node is a text node -- child::node()[1]/self::text().
These are harder to read in XPath as they are spanning multiple steps, so having shorthand selectors for these could be useful.
NOTE: I don't have any concrete proposals for this.
Using first-child::element-name and first-child::text() would be easier to read. The former is CSS-like (match elements only), while the latter is XPath-like (match any nodes). Using different context behaviour would be confusing, and inconsistent with the other XPath axis selectors. It would also prevent supporting a child::node()[1]/self::element-name equivalent.
Another possibility would be to create two separate axes, such as first-child and first-child-element. This would be consistent with axes like ancestor/ancestor-or-self, but could quickly increase the number of axes. This version would add at least 4 new axes:
first-child:: (forward);
first-child-element:: (forward);
last-child:: (reverse);
last-child-element:: (reverse).
NOTE: Only the tree traversal CSS selectors would be applicable. CSS selectors like E:hover require context information that is not available, nor relevant to XPath.
Reference: https://drafts.csswg.org/selectors-4/#overview <https://drafts.csswg.org/selectors-4/#overview>
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub <#19>, or unsubscribe <https://github.com/notifications/unsubscribe-auth/AASIQIXT2QINV2DFKLE6RB3RLICAPANCNFSM4MCNZBSA>.
|
I agree w.r.t. orthogonality. Your proposed syntax (which I like) would work differently for the first example. There, it is matching the first element child (not general node) if it has the specified name, so would ignore text/comment nodes. That is, it would sometimes be useful to apply axes on elements only instead of all children. |
i often see people leave out the * before a predictate, /a/b/[last()]orwhatever (meaning the last "b" element, or perhaps meaning the last child of b. So making it legal would turn a syntax error into a legal but potentially wrong expression. Is *[1][self::span] so hard? Since child is the default we can already omit that part. |
I've found myself wanting to write XPath expressions equivalent or similar to the CSS
E:first-child
selector. The two use cases I have so far is:child::*[1]/self::element-name
;child::node()[1]/self::text()
.These are harder to read in XPath as they are spanning multiple steps, so having shorthand selectors for these could be useful.
NOTE: I don't have any concrete proposals for this.
Using
first-child::element-name
andfirst-child::text()
would be easier to read. The former is CSS-like (match elements only), while the latter is XPath-like (match any nodes). Using different context behaviour would be confusing, and inconsistent with the other XPath axis selectors. It would also prevent supporting achild::node()[1]/self::element-name
equivalent.Another possibility would be to create two separate axes, such as
first-child
andfirst-child-element
. This would be consistent with axes likeancestor
/ancestor-or-self
, but could quickly increase the number of axes. This version would add at least 4 new axes:first-child::
(forward);first-child-element::
(forward);last-child::
(reverse);last-child-element::
(reverse).NOTE: Only the tree traversal CSS selectors would be applicable. CSS selectors like
E:hover
require context information that is not available, nor relevant to XPath.Reference: https://drafts.csswg.org/selectors-4/#overview
The text was updated successfully, but these errors were encountered: