I have two div. <div class="card" id="openWebsite">
and sub div <div class="card__btn">
If someone clicks on my root div they will get redirected to example.com
and when someone clicks sub div they are redirected to example.com
& example.net
, they are getting redirected two both links in two new tab.
I want, if someone clicks on root div they should get redirected to example.com
and when someone clicks on sub div button they should only be redirected to example.net
not example.com
how to exclude sub div <div class="card__btn">
from javascript.
Code :
const webPage = document.querySelectorAll("#openWebsite");
webPage.forEach((e) => {
e.addEventListener("click", () => {
const site = e.getAttribute("data-site");
window.open(site, "_blank") || window.location.replace(site);
});
});
.card {
background: blue;
height: 100px;
width: 500px;
}
<div class="card" id="openWebsite" data-site="https://example.com">
<div class="card__btn">
<a href="https://example.net">
Visit Site
</a>
</div>
</div>
Already tried from jQuery exclude elements with certain class in selector , https://api.jquery.com/not/ , document.querySelector exclude part of DOM, https://www.w3schools.com/jsref/met_document_queryselectorall.asp
document.querySelectorAll("#openWebsite").not(".card__btn");
and
document.querySelectorAll(".card").not(".card__btn");
and
document.querySelectorAll("#openWebsite:not('.card__btn')");
3
Answers
You need to make you internal div position absolute then it will work the way you want.
there
your code is absolutely fine, just that you used
instead of
only, because you only have one id on your page with the id "openWebsite",
below is a suggestion I believe you can add to your css to make your project more visible
Events bubble up the dom. When you click on the anchor it opens
example.net
.Then it goes up the tree and your event handler is triggered, causing
example.com
to be opened.To stop this you can use
Event.stopPropagation
. That way, the event won’t continue going up the tree.Because stackoverflow doesn’t allow new tabs to be opened, I have also created a fiddle.