Suppose
JavaScript
x
5
1
<div myattr='user1'>abcd</div>
2
<div myattr='user2'>1234</div>
3
<div myattr='user2'>wxyz</div>
4
<div myattr='user3'>7890</div>
5
For now third element’s display must be none.
I tried
JavaScript
1
4
1
div[myattr='user2'] ~ div[myattr='user2'] {
2
display: none;
3
}
4
But this code only works for element whose myattr
is user2
not for other users / attribute values and this sets display of third element to none instead of second.
I want to set some styles to every element whose next element have same attribute.
How can I achieve this?
CSS code is preferred but JavaScript can also work here.
Advertisement
Answer
Because you want to refer back to the earlier element’s attribute value, I don’t think you can do this with CSS. It’s fairly straightforward with JavaScript:
JavaScript
1
7
1
for (const entry of document.querySelectorAll("[data-myattr]")) {
2
const next = entry.nextElementSibling;
3
if (next.getAttribute("data-myattr") === entry.getAttribute("data-myattr")) {
4
entry.classList.add("hidden");
5
}
6
}
7
Live Example:
JavaScript
1
11
11
1
const display = document.getElementById("display");
2
display.textContent = "Before";
3
setTimeout(() => {
4
for (const entry of document.querySelectorAll("[data-myattr]")) {
5
const next = entry.nextElementSibling;
6
if (next.getAttribute("data-myattr") === entry.getAttribute("data-myattr")) {
7
entry.classList.add("hidden");
8
}
9
}
10
display.textContent = "After";
11
}, 1000);
JavaScript
1
3
1
.hidden {
2
display: none;
3
}
JavaScript
1
18
18
1
<div id="display"></div>
2
<hr>
3
<div data-myattr='user1'>first user1</div>
4
<div data-myattr='user2'>first user2</div>
5
<div data-myattr='user2'>second user2</div>
6
<div data-myattr='user3'>first user3</div>
7
<hr>
8
<div data-myattr='user1'>first user1</div>
9
<div data-myattr='user2'>first user2</div>
10
<div data-myattr='user3'>first user3</div>
11
<div data-myattr='user3'>second user3</div>
12
<div data-myattr='user3'>third user3</div>
13
<hr>
14
<div data-myattr='user1'>first user1</div>
15
<div data-myattr='user2'>first user2</div>
16
<div data-myattr='user3'>first user3</div>
17
<div data-myattr='user2'>second user2 but not in a row</div>
18
<div data-myattr='user3'>second user3 but not in a row</div>
Side note: I’ve used data-myattr
rather than myattr
above because custom attributes should always use the data-
prefix.