Lets say that we have the following code:
<node>
<element bla="1"/>
<element bla="2"/>
<element bla="3"/>
<element bla="3"/>
<element bla="3"/>
<element bla="4"/>
</node>
How would you go about selecting the first child that has attribute equal to 3? I was thinking that perhaps this could do the job:
element[bla="3"]:first-child
...but it did not work
The :first-child selector is used to select the specified selector, only if it is the first child of its parent.
To create a CSS child selector, you use two selectors. The child combinator selects elements that match the second selector and are the direct children of the first selector. Operators make it easier to find elements that you want to style with CSS properties.
The :first-of-type selector in CSS allows you to target the first occurence of an element within its container. It is defined in the CSS Selectors Level 3 spec as a “structural pseudo-class”, meaning it is used to style content based on its relationship with parent and sibling content.
The [attribute|="value"] selector is used to select elements with the specified attribute, whose value can be exactly the specified value, or the specified value followed by a hyphen (-). Note: The value has to be a whole word, either alone, like class="top", or followed by a hyphen( - ), like class="top-text".
:not([bla="3"]) + [bla="3"] {
color: red;
}
<div>
<p bla="1">EL1</p>
<p bla="2">EL2</p>
<p bla="3">EL3</p>
<p bla="3">EL3</p>
<p bla="3">EL3</p>
<p bla="4">EL4</p>
</div>
The :first-child
pseudo-class only looks at the first child node, so if the first child isn't an element[bla="3"]
, then nothing is selected.
There isn't a similar filter pseudo-class for attributes. An easy way around this is to select every one then exclude what comes after the first (this trick is explained here and here):
element[bla="3"] {
}
element[bla="3"] ~ element[bla="3"] {
/* Reverse the above rule */
}
This, of course, only works for applying styles; if you want to pick out that element for purposes other than styling (since your markup appears to be arbitrary XML rather than HTML), you'll have to use something else like document.querySelector()
:
var firstChildWithAttr = document.querySelector('element[bla="3"]');
Or an XPath expression:
//element[@bla='3'][1]
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With