简体   繁体   中英

How to override css using javascript?

I created an html page with 3 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 2.
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 don't know any jQuery so please don't give solutions in it)

 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>

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>

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');
});

I hope it helps you! Happy coding!

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

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM