You can achieve quite a cool custom checkbox effect by using the new abilities that come with the :after
and :before
pseudo classes. The advantage to this, is: You don't need to add anything more to the dom, just the standard checkbox.
Note this will only work for compatible browsers, I believe this is related to the fact that some browsers do not allow you to set :after
and :before
on input elements. Which unfortunately means for the moment only webkit browsers are supported. FF + IE will still allow the check-boxes to function, just un-styled, and this will hopefully change in the future (the code does not use vendor prefixes).
This is a Webkit browser solution only (Chrome, Safari, Mobile browsers)
.myinput[type="checkbox"]:before{
position: relative;
display: block;
width: 11px;
height: 11px;
border: 1px solid #808080;
content: "";
background: #FFF;
}
.myinput[type="checkbox"]:after{
position: relative;
display: block;
left: 2px;
top: -11px;
width: 7px;
height: 7px;
border-width: 1px;
border-style: solid;
border-color: #B3B3B3 #dcddde #dcddde #B3B3B3;
content: "";
background-image: linear-gradient(135deg, #B1B6BE 0%,#FFF 100%);
background-repeat: no-repeat;
background-position:center;
}
.myinput[type="checkbox"]:checked:after{
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAHCAQAAABuW59YAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAB2SURBVHjaAGkAlv8A3QDyAP0A/QD+Dam3W+kCAAD8APYAAgTVZaZCGwwA5wr0AvcA+Dh+7UX/x24AqK3Wg/8nt6w4/5q71wAAVP9g/7rTXf9n/+9N+AAAtpJa/zf/S//DhP8H/wAA4gzWj2P4lsf0JP0A/wADAHB0Ngka6UmKAAAAAElFTkSuQmCC'), linear-gradient(135deg, #B1B6BE 0%,#FFF 100%);
}
.myinput[type="checkbox"]:disabled:after{
-webkit-filter: opacity(0.4);
}
.myinput[type="checkbox"]:not(:disabled):checked:hover:after{
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAcAAAAHCAQAAABuW59YAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAB2SURBVHjaAGkAlv8A3QDyAP0A/QD+Dam3W+kCAAD8APYAAgTVZaZCGwwA5wr0AvcA+Dh+7UX/x24AqK3Wg/8nt6w4/5q71wAAVP9g/7rTXf9n/+9N+AAAtpJa/zf/S//DhP8H/wAA4gzWj2P4lsf0JP0A/wADAHB0Ngka6UmKAAAAAElFTkSuQmCC'), linear-gradient(135deg, #8BB0C2 0%,#FFF 100%);
}
.myinput[type="checkbox"]:not(:disabled):hover:after{
background-image: linear-gradient(135deg, #8BB0C2 0%,#FFF 100%);
border-color: #85A9BB #92C2DA #92C2DA #85A9BB;
}
.myinput[type="checkbox"]:not(:disabled):hover:before{
border-color: #3D7591;
}
.myinput.large{
height:22px;
width:22px;
}
.myinput.large[type="checkbox"]:before{
width: 20px;
height: 20px;
}
.myinput.large[type="checkbox"]:after{
top: -20px;
width: 16px;
height: 16px;
}
.myinput.large.custom[type="checkbox"]:checked:after{
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGHRFWHRBdXRob3IAbWluZWNyYWZ0aW5mby5jb23fZidLAAAAk0lEQVQ4y2P4//8/AyUYwcAD+OzN/oMwshjRBoA0Gr8+DcbIhhBlAEyz+qZZ/7WPryHNAGTNMOxpJvo/w0/uP0kGgGwGaZbrKgfTGnLc/0nyAgiDbEY2BCRGdCDCnA2yGeYVog0Aae5MV4c7Gzk6CRqAbDM2w/EaQEgzXgPQnU2SAcTYjNMAYm3GaQCxNuM0gFwMAPUKd8XyBVDcAAAAAElFTkSuQmCC'), linear-gradient(135deg, #B1B6BE 0%,#FFF 100%);
}
.myinput.large.custom[type="checkbox"]:not(:disabled):checked:hover:after{
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGHRFWHRBdXRob3IAbWluZWNyYWZ0aW5mby5jb23fZidLAAAAk0lEQVQ4y2P4//8/AyUYwcAD+OzN/oMwshjRBoA0Gr8+DcbIhhBlAEyz+qZZ/7WPryHNAGTNMOxpJvo/w0/uP0kGgGwGaZbrKgfTGnLc/0nyAgiDbEY2BCRGdCDCnA2yGeYVog0Aae5MV4c7Gzk6CRqAbDM2w/EaQEgzXgPQnU2SAcTYjNMAYm3GaQCxNuM0gFwMAPUKd8XyBVDcAAAAAElFTkSuQmCC'), linear-gradient(135deg, #8BB0C2 0%,#FFF 100%);
}
Revisions
- August 10, 2016 @ 19:21:36 [Current Revision] by admin
- August 10, 2016 @ 19:21:36 by admin
I like the helpful information you provide in your articles.
I will bookmark your blog and test again right here frequently.
I’m reasonably certain I’ll learn many new stuff proper right
here! Best of luck for the following!
I know this if off topic but I’m looking into starting my own blog and
was wondering what all is needed to get setup?
I’m assuming having a blog like yours would cost a pretty penny?
I’m not very web smart so I’m not 100% certain. Any recommendations or advice would be greatly appreciated.
Thanks
Spot on with this write-up, I actually feel this site
needs much more attention. I’ll probably be back again to read more, thanks for the info!
Hey there! Would you mind if I share your blog with
my facebook group? There’s a lot of people that I think
would really enjoy your content. Please let me know.
Thanks
Hi,
It is fine for me. You can do it 🙂
Regards.
“I simply could not leave your website before suggesting that I really enjoyed the standard info a person supply for your visitors. Is gonna be back continuously in order to check up on new posts?”
I will continue writing the new posts to help you and other developers.
Thanks for your feedback 🙂
There is certainly noticeably a bundle to know about this. I assume you produced specific nice points in attributes also.