Reputation: 530
I created an HTML page with three square images, every image is in a checkbox's label. I created a JavaScript function which checks how many checkboxes are checked.
On every input (which is a checkbox) I add an event listener, the goal of it is to limit The number of checked checkboxes to two. I used CSS so when an image is checked or hovered a red border appears.
My problem is that when I uncheck an image because my mouse is still on it I can't see that it was unchecked until my mouse isn't on the image.
So how can I override the CSS and hide or delete the border when an image is unchecked even if the mouse is still on it? I would like to use plain JavaScript for this.
function checkedtimes(checkboxes) {
return checkboxes
.map(checkbox => document.getElementById(checkbox).checked)
.reduce((x, y) => x + y)
}
let logos = ["green","yellow","blue"]
for (let logo of logos) {
logo = document.getElementById(logo)
logo.addEventListener('change', e=> {
e.preventDefault()
if (logo.checked) {
if (checkedtimes(logos)>2) {
logo.checked = false
}
}
else {
}
})
}
#logos {
display: flex;
justify-content: center;
}
.logo {
display: none;
}
.logo-label {
display: inline-block;
margin: 10px;
text-align: center;
}
.logo:checked + .logo-label>img, .logo:hover + .logo-label>img {
border: solid 2px red;
}
<head>
</head>
<body>
<form id="form">
<div id="logos">
<input type="checkbox" id="green" class="logo" />
<label for="green" class="logo-label">
<img src="">
<br>
green
</label>
<input type="checkbox" id="yellow" class="logo"/>
<label for="yellow" class="logo-label">
<img src="">
<br>
yellow
</label>
<input type="checkbox" id="blue" class="logo"/>
<label for="blue" class="logo-label">
<img src="">
<br>
blue
</label>
</div>
</form>
</body>
Upvotes: 2
Views: 507
Reputation: 1049
You can just use style.setProperty(string, string)
. The first parameter is the CSS atttribute and the second parameter is the CSS value. Both of them need to be strings
in order to work.
let element = document.getElementById("element-id")
element.style.setProperty('color', '#ffffff');
To know if the mouse is still hover the element you can create an event listener on the element.
element.addEventListener("mouseover", () => {
element.style.setProperty('color', '#ffffff');
});
element.addEventListener("mouseout", () => {
element.style.setProperty('color', '#000000');
});
Upvotes: 1
Reputation: 8318
This is more js oriented solution but I guess can work for you.
I am using mouseenter
and mouseleave
on img
to simulate hover.
An additional click
event on the img
such that if the logo
was checked and you clicked on the img
, the border
will be set to none
else border
will be set to solid 2px red
.
function checkedtimes(checkboxes) {
return checkboxes
.map(checkbox => document.getElementById(checkbox).checked)
.reduce((x, y) => x + y)
}
let logos = ["green","yellow","blue"]
for (let logo of logos) {
logo = document.getElementById(logo)
logo.addEventListener('change', e=> {
e.preventDefault()
if (logo.checked) {
if (checkedtimes(logos)>2) {
logo.checked = false
}
}
else {
}
})
const image = logo.nextElementSibling.firstElementChild;
image.addEventListener('mouseenter',e=>{
if(!logo.checked){
image.style.border = 'solid 2px red';
}
})
image.addEventListener('mouseleave',e=>{
if(!logo.checked){
image.style.border = 'none';
}
})
image.addEventListener('click',e=>{
if(logo.checked){
image.style.border = 'none';
}
else {
image.style.border = 'solid 2px red';
}
})
}
#logos {
display: flex;
justify-content: center;
}
.logo {
display: none;
}
.logo-label {
display: inline-block;
margin: 10px;
text-align: center;
}
.logo:checked + .logo-label>img {
border: solid 2px red;
}
<head>
</head>
<body>
<form id="form">
<div id="logos">
<input type="checkbox" id="green" class="logo" />
<label for="green" class="logo-label">
<img src="">
<br>
green
</label>
<input type="checkbox" id="yellow" class="logo"/>
<label for="yellow" class="logo-label">
<img src="">
<br>
yellow
</label>
<input type="checkbox" id="blue" class="logo"/>
<label for="blue" class="logo-label">
<img src="">
<br>
blue
</label>
</div>
</form>
</body>
Upvotes: 2
Reputation: 121
I think the problem is related to your css styling, as you are displaying a border around the picture when the mouse hovers over it. Please change your css by removing :hover
.logo:checked + .logo-label>img{
border: solid 2px red;
}
Modified code snippet is below
function checkedtimes(checkboxes) {
return checkboxes
.map(checkbox => document.getElementById(checkbox).checked)
.reduce((x, y) => x + y)
}
let logos = ["green","yellow","blue"]
for (let logo of logos) {
logo = document.getElementById(logo)
logo.addEventListener('change', e=> {
e.preventDefault()
if (logo.checked) {
if (checkedtimes(logos)>2) {
logo.checked = false
}
}
else {
}
})
}
#logos {
display: flex;
justify-content: center;
}
.logo {
display: none;
}
.logo-label {
display: inline-block;
margin: 10px;
text-align: center;
}
.logo:checked + .logo-label>img{
border: solid 2px red;
}
<body>
<form id="form">
<div id="logos">
<input type="checkbox" id="green" class="logo" />
<label for="green" class="logo-label">
<img src="">
<br>
green
</label>
<input type="checkbox" id="yellow" class="logo"/>
<label for="yellow" class="logo-label">
<img src="">
<br>
yellow
</label>
<input type="checkbox" id="blue" class="logo"/>
<label for="blue" class="logo-label">
<img src="">
<br>
blue
</label>
</div>
</form>
</body>
Just run code and check does it fit to you
Upvotes: 0