I am trying to get the targeted element with the pseudo-class :target
after document load.
I created the following example to illustrate the problem.
<!DOCTYPE html>
<html>
<head>
<script>
document.addEventListener("DOMContentLoaded",function(){
console.log(document.querySelector(":target"));
});
</script>
</head>
<body>
<div id="test"></div>
</body>
</html>
If I load test.html
, then the console outputs :
null
If I load test.html#test
on Chrome and Opera, then the console outputs :
null
If I load test.html#test
on Firefox and IE11, then the console outputs :
<div id="test"></div>
My questions are :
- Which browsers have the correct behaviour ?
- Does
DOMContentLoaded
is the correct event to callquerySelector(":target")
? - Is there another way to get targeted element after document load ?
PS : I succeeded to fix the problem on Chrome and Opera thanks to setTimeout
but It is not a good solution. Does someone has a better idea ?
EDIT : I found a similar issue with JQuery Selecting :target on document.ready()
It looks like Firefox has the ideal behaviour, though maybe not the correct one.
Nevertheless, as an alternative, you can use:
and that will work in all browsers.