I know that is a bad practice to have more than HTML elements having same ID. However such is my situation where I need to specifically modify either of them.
I researched around and found about Jquery method ‘document.getElementByID’ that returns with the first similar element and lets you change it using css. Using that I wrote the code below but it doesn’t work.
$(document.getElementById('it_trending-3')).css({"display":"none"});
I have added this code in my wordpress theme using the CSS-JS-PHP wordpress plugin, created a shortcut from the same and then added the shortcode. Can someone please guide me what and where I went wrong?
Also feel free to suggest a different function that would maybe let me specifically point to each of the same ID elements using maybe indexes. Thanks!
Keep a class to the divs you want to change:
The Jquery would go like this:
But if you want to select any specific element with the class via an index of sorts, then you would need to do it like this:
You can achieve this in 2 ways.
Based on element’s hierarchy or based on class attribute / custom data attribute to the element.
In the below example we have 3 span elements with the same id and we have to apply 3 colors to each of those span elements.
HTML
JQuery
JQuery
JS Fiddle Demo