Tips on designing checkboxes with CSS

Can someone help me figure out how to style a checkbox using the code below?

<input type="checkbox" style="border:2px dotted #00f;display:block;background:#ff0000;" />

I've tried applying this style but it doesn't seem to work. The checkbox is still showing its default style. Any suggestions on how to make the specified styles show up properly?

Answer №1

UPDATE:

Before the widespread availability of CSS 3, creating custom checkbox replacements required JavaScript. However, in modern browsers like Internet Explorer 9 and later, it is now easier to style checkboxes using CSS without the need for JavaScript.

For more information on how to create custom form checkboxes with CSS, check out these helpful links:

  • Creating Custom Form Checkboxes with Just CSS
  • Easy CSS Checkbox Generator
  • Stuff You Can Do With The Checkbox Hack
  • Implementing Custom Checkboxes and Radio Buttons with CSS3
  • How to Style a Checkbox With CSS

Although you still can't directly apply styles to the checkbox element itself, it is now possible to hide the default checkbox and replace it with a styled element using only CSS. This method allows you to reflect the checked status of the box using the :checked selector.


OLDER ANSWER

If you're interested in styling checkboxes, this article discusses the challenges that come with browser compatibility when trying to style checkboxes. Some browsers may always display the default checkbox despite styling attempts.

One workaround is using JavaScript to overlay an image on the checkbox and have clicks on the image trigger the checkbox check. Users without JavaScript enabled would see the default checkbox.

Additionally, here's a useful script that hides the real checkbox, replaces it with a styled span, and handles click events accordingly.

Answer №2

If you want to create a unique and stylish checkbox design, consider using the :after and :before pseudo classes. The great thing about this method is that you don't have to clutter your DOM with additional elements, just utilize the standard checkbox.

Please note that this approach works best on compatible browsers like Chrome and Safari, as some browsers may not fully support the use of :after and :before on input elements. Despite limitations in Firefox and Internet Explorer, the checkboxes will still work but appear unstyled. Hopefully, future updates will address this issue without requiring vendor prefixes.

This solution is intended for WebKit browsers only, including Chrome, Safari, and mobile browsers.

Check out an Example Fiddle Here

$(function() {
  $('input').change(function() {
    $('div').html(Math.random());
  });
});
/* Main Classes */
.myinput[type="checkbox"]:before {
  position: relative;
  display: block;
  width: 11px;
  height: 11px;
  border: 1px solid #808080;
  content: "";
  background: #FFF;
}

... (CSS styles continue)

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<table style="width:100%">
  <tr>
    ... (table rows continue)
  </tr>
  <tr>
    ... (additional table rows)
  </tr>
</table>

Explore a Bonus Webkit Style Flipswitch Fiddle

$(function() {
  var f = function() {
    $(this).next().text($(this).is(':checked') ? ':checked' : ':not(:checked)');
  };
  $('input').change(f).trigger('change');
});
body {
  font-family: arial;
}

.flipswitch {
  position: relative;
  background: white;
  width: 120px;
  height: 40px;
  -webkit-appearance: initial;
  ... (continued CSS styles)
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>

<h2>Webkit friendly mobile-style checkbox/flipswitch</h2>
<input type="checkbox" class="flipswitch" /> &nbsp;
<span></span>
<br>
<input type="checkbox" checked="checked" class="flipswitch" /> &nbsp;
<span></span>

Answer №3

Updated Information (as of Jan 2021)

The original question and answer were posted about 5 years ago, so it's time for a refresh.

When it comes to styling checkboxes, there are multiple approaches to consider:

  1. You must hide the default checkbox control provided by the browser because CSS cannot fully override its styling.

  2. Even with the checkbox hidden, you still need to detect and toggle its checked state.

  3. To visually represent the checked state, you'll need to style a new element.

Possible Solutions

There are various ways to achieve this task, and while CSS3 pseudo-elements are often recommended, the best approach depends on your specific needs. Here is one suggested method:

  1. Enclose your checkbox within a label tag. This allows the user to click anywhere within the label to toggle the checkbox.

  2. Hide the actual checkbox itself.

  3. Add a new element after the checkbox that can be styled to indicate the checked state. Placing it after the checkbox enables CSS selection based on the :checked state.

Implementation (with Code Example)

label input {
  visibility: hidden;/* <-- Hide the default checkbox. The rest is to hide and allow tabbing, which display:none prevents */
  display: block;
  height: 0;
  width: 0;
  position: absolute;
  overflow: hidden;
}
label span {/* <-- Style the artificial checkbox */
  height: 10px;
  width: 10px;
  border: 1px solid grey;
  display: inline-block;
}
[type=checkbox]:checked + span {/* <-- Style its checked state */
  background: black;
}
<label>
  <input type='checkbox'>
  <span></span>
  Checkbox label text
</label>

Enhancement (Using Icons)

If you want to include icons like a tick or cross without using background images, CSS3 pseudo-elements can be helpful. These allow you to add Unicode icons representing different states or use a font icon library like Font Awesome (remember to set the correct font-family).

label input {
  display: none; /* Hide the default checkbox */
}

/* Style the artificial checkbox */
label span {
  height: 10px;
  width: 10px;
  border: 1px solid grey;
  display: inline-block;
  position: relative;
}

/* Style its checked state with a ticked icon */
[type=checkbox]:checked + span:before {
  content: '\2714';
  position: absolute;
  top: -5px;
  left: 0;
}
<label>
  <input type='checkbox'>
  <span></span>
  Checkbox label text
</label>

Answer №4

One innovative way to achieve this effect is by utilizing only CSS. By manipulating the label element, we can create a visually appealing design for checkboxes. It's worth noting that this method may not be compatible with Internet Explorer 8 and earlier versions.

.myCheckbox input {
  position: relative;
  z-index: -9999;
}

.myCheckbox span {
  width: 20px;
  height: 20px;
  display: block;
  background: url("link_to_image");
}

.myCheckbox input:checked + span {
  background: url("link_to_another_image");
}
<label for="test">Label for my styled "checkbox"</label>
<label class="myCheckbox">
  <input type="checkbox" name="test" />
  <span></span>
</label>

Answer №5

Revolutionary approach to accessibility - integrating accent-color

The latest technique involves utilizing the innovative accent-color property while ensuring a proper contrast ratio of 3:1 for enhanced accessibility. This method is effective even with radio buttons.

.red-input {
    accent-color: #9d3039;
    height: 20px; /* can be omitted */
    width: 20px; /* can be omitted */
}
<input class="red-input" type="checkbox" />

<!-- Example of Radio button -->
<input class="red-input" type="radio" />


Traditional solution, recommended only when advanced customization is necessary:

Many solutions overlook accessibility concerns and end up breaching WCAG guidelines in multiple ways. Alongside custom checkboxes, providing customized radio buttons is advisable in most scenarios.

Code Demos:

Lagging behind in time but still challenging in 2019, 2020, 2021, I introduce three accessible and user-friendly solutions.

All these solutions are devoid of JavaScript, ensure accessibility, and eliminate reliance on external libraries*...

To swiftly implement any of these styles, copy the style sheet from the demos, tweak the color codes in the CSS as needed, and seamlessly integrate them into your project. Custom SVG checkmark icons can also be included for checkboxes. Ample comments are provided for non-CSS individuals.

If text wrapping issues arise beneath checkbox or radio input within a cramped container due to lengthy text, consider switching to div elements like this.

Detailed Explanation: My quest was to find a viable solution that adheres to WCAG recommendations, excludes JavaScript or third-party frameworks, maintains smooth keyboard navigation functionality, incorporates focus events, caters to disabled checkboxes—whether checked or unchecked—, and finally offers limitless customization possibilities for checkbox appearance using varied properties like background-color, border-radius, svg backgrounds, etc.

Inspirations were drawn from this guide shared by @Jan Turoň which led me to formulate my own satisfactory solution. The radio button demonstration shares resemblance with the checkbox logic to enable compatibility.

I'm continuously learning about accessibility nuances, so feedback pointing out oversights is highly appreciated for rectification.

This snippet illustrates my checkbox implementation:

input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  z-index: -1;
}

/* Label's text color */
input[type="checkbox"]+span {
  cursor: pointer;
  font: 16px sans-serif;
  color: black;
}

/* Unchecked checkbox style */
input[type="checkbox"]+span:before {
  content: '';
  border: 1px solid grey;
  border-radius: 3px;
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 0.5em;
  margin-top: 0.5em;
  vertical-align: -2px;
}

/* Styling for checked checkbox (green background here #e7ffba, adjustable to desired color) */
input[type="checkbox"]:checked+span:before {
  background-image: url('https://cdnjs.cloudflare.com/ajax/libs/ionicons/4.5.6/collection/build/ionicons/svg/ios-checkmark.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 25px;
  border-radius: 2px;
  background-color: #e7ffba;
  color: white;
}

/* Dotted border around focused checkbox */
input[type="checkbox"]:focus+span:before,
input[type="checkbox"]:not(:disabled)+span:hover:before {
  box-shadow: 0px 0px 0px 2px rgba(0, 150, 255, 1);
  outline-color: transparent;
  outline-width: 2px;
  outline-style: dotted;
}

/* Disabled checkbox styles */
input[type="checkbox"]:disabled+span {
  cursor: default;
  color: black;
  opacity: 0.5;
}

/* Specific fiddle styles that may not be essential */
body {
  padding: 1em;
}
h1 {
  font-size: 18px;
}
<h1>
  NOTE: Modify the URL for background-image path in CSS depending on chosen SVG source. The current one was sourced from an internet search for a checkmark icon CDN
</h1>

<p>Easily adjust background color, checkbox symbol, border-radius, etc.</p>

<label>
  <input type="checkbox">
  <span>Try tabbing and space usage</span>
</label>

<br>

<label>
  <input type="checkbox" checked disabled>
  <span>Inactive Checked Checkbox</span>
</label>

<br>

<label>
  <input type="checkbox" disabled>
  <span>Disabled Checkbox</span>
</label>
<br>

<label>
  <input type="checkbox">
  <span>Standard Checkbox</span>
</label>

<br>

<label>
  <input type="checkbox">
  <span>Another Standard Checkbox</span>
</label>

Answer №6

I have found a great solution for customizing the appearance of checkboxes and radio buttons by using pseudo elements :before and :after. It works like magic!

To learn more about this technique, check out this link.

If you want to see the code in action, visit this CODEPEN demo.

Here are the steps:

  1. Start by hiding the default checkbox using CSS rules such as visibility:hidden, opacity:0, or position:absolute;left:-9999px.
  2. Create a custom checkbox using the :before element and provide an empty space or non-breaking space '\00a0';
  3. When the checkbox is checked (:checked state), display a checkmark unicode content: "\2713";
  4. Add styles for focus to make the checkbox accessible;
  5. You're done!

Below is an example of how I implemented this technique:

.box {
  background: #666666;
  color: #ffffff;
  width: 250px;
  padding: 10px;
  margin: 1em auto;
}
p {
  margin: 1.5em 0;
  padding: 0;
}
input[type="checkbox"] {
  visibility: hidden;
}
label {
  cursor: pointer;
}
input[type="checkbox"] + label:before {
  border: 1px solid #333;
  content: "\00a0";
  display: inline-block;
  font: 16px/1em sans-serif;
  height: 16px;
  margin: 0 .25em 0 0;
  padding: 0;
  vertical-align: top;
  width: 16px;
}
input[type="checkbox"]:checked + label:before {
  background: #fff;
  color: #333;
  content: "\2713";
  text-align: center;
}
input[type="checkbox"]:checked + label:after {
  font-weight: bold;
}

input[type="checkbox"]:focus + label::before {
    outline: rgb(59, 153, 252) auto 5px;
}
<div class="content">
  <div class="box">
    <p>
      <input type="checkbox" id="c1" name="cb">
      <label for="c1">Option 01</label>
    </p>
    <p>
      <input type="checkbox" id="c2" name="cb">
      <label for="c2">Option 02</label>
    </p>
    <p>
      <input type="checkbox" id="c3" name="cb">
      <label for="c3">Option 03</label>
    </p>
  </div>
</div>

For a more stylish implementation using :before and :after:

body{
  font-family: sans-serif;  
}

.container {
    margin-top: 50px;
    margin-left: 20px;
    margin-right: 20px;
}
.checkbox {
    width: 100%;
    margin: 15px auto;
    position: relative;
    display: block;
}

.checkbox input[type="checkbox"] {
    width: auto;
    opacity: 0.00000001;
    position: absolute;
    left: 0;
    margin-left: -20px;
}
.checkbox label {
    position: relative;
}
.checkbox label:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    margin: 4px;
    width: 22px;
    height: 22px;
    transition: transform 0.28s ease;
    border-radius: 3px;
    border: 2px solid #7bbe72;
}
.checkbox label:after {
  content: '';
    display: block;
    width: 10px;
    height: 5px;
    border-bottom: 2px solid #7bbe72;
    border-left: 2px solid #7bbe72;
    -webkit-transform: rotate(-45deg) scale(0);
    transform: rotate(-45deg) scale(0);
    transition: transform ease 0.25s;
    will-change: transform;
    position: absolute;
    top: 12px;
    left: 10px;
}
.checkbox input[type="checkbox"]:checked ~ label::before {
    color: #7bbe72;
}

.checkbox input[type="checkbox"]:checked ~ label::after {
    -webkit-transform: rotate(-45deg) scale(1);
    transform: rotate(-45deg) scale(1);
}

.checkbox label {
    min-height: 34px;
    display: block;
    padding-left: 40px;
    margin-bottom: 0;
    font-weight: normal;
    cursor: pointer;
    vertical-align: sub;
}
.checkbox label span {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.checkbox input[type="checkbox"]:focus + label::before {
    outline: 0;
}
<div class="container"> 
  <div class="checkbox">
     <input type="checkbox" id="checkbox" name="" value="">
     <label for="checkbox"><span>Checkbox</span></label>
  </div>

  <div class="checkbox">
     <input type="checkbox" id="checkbox2" name="" value="">
     <label for="checkbox2"><span>Checkbox</span></label>
  </div>
</div>

Answer №7

I used to follow SW4's advice from this post. However, I now believe that Volomike's answer in this response is the best solution (please see my comment for an improvement suggestion). Keep reading if you're interested in exploring different approaches mentioned in this answer.


To begin with, consider hiding the checkbox and replacing it with a custom span, as shown in the following HTML:

<label>
  <input type="checkbox">
  <span>send newsletter</span>
</label>

The use of a label allows users to click the text without needing to link it via the "for-id" attribute. However,

Avoid using visibility: hidden or display: none

While these methods may work when clicking or tapping, they are not efficient ways to interact with checkboxes. Some individuals prefer using the Tab key to move focus and the Space key to activate, but hiding the checkbox in this manner disables such functionality. For longer forms, incorporating attributes like tabindex or accesskey can help prevent strain on the user’s wrists. Additionally, a well-styled checkbox should mimic the system's hover effects.

In cobberboy's response, Font Awesome is recommended for its scalability compared to bitmap images. When using the provided HTML structure, the following CSS rules are suggested:

  1. Hide checkboxes

     input[type="checkbox"] {
       position: absolute;
       opacity: 0;
       z-index: -1;
     }
    

    The use of a negative z-index ensures that the custom checkbox graphics cover the original checkbox entirely. It's advised against using left: -999px as it might not be universally applicable across all layouts. Alternatively, Bushan wagh's solution provides a more foolproof method for hiding checkboxes while preserving tabindex functionality. Both approaches are somewhat unconventional hacks, with the preferred modern technique being appearance: none, as mentioned in Joost's answer:

     input[type="checkbox"] {
       appearance: none;
       -webkit-appearance: none;
       -moz-appearance: none;
     }
    
  2. Style checkbox label

     input[type="checkbox"] + span {
       font: 16pt sans-serif;
       color: #000;
     }
    
  3. Add checkbox skin

     input[type="checkbox"] + span:before {
       font: 16pt FontAwesome;
       content: '\00f096';
       display: inline-block;
       width: 16pt;
       padding: 2px 0 0 3px;
       margin-right: 0.5em;
     }
    

The character \00f096 corresponds to Font Awesome's square-o, and the padding adjustments ensure an even dotted outline upon focusing (as described below).

  1. Add checked checkbox skin

     input[type="checkbox"]:checked + span:before {
       content: '\00f046';
     }
    

The character \00f046 represents Font Awesome's check-square-o, which has a different width than square-o, hence the specified width style above.

  1. Add focus outline

     input[type="checkbox"]:focus + span:before {
       outline: 1px dotted #aaa;
     }
    

    Note that Safari lacks support for this feature (refer to @Jason Sankey's comment), with a specific CSS solution outlined in this answer solely for Safari browsers.

  2. Set gray color for disabled checkbox

     input[type="checkbox"]:disabled + span {
       color: #999;
     }
    
  3. Apply hover shadow on non-disabled checkbox

     input[type="checkbox"]:not(:disabled) + span:hover:before {
       text-shadow: 0 1px 2px #77F;
     }
    

Explore the interactive example on JS Fiddle

Hover over the checkboxes, navigate using Tab and Shift+Tab, and utilize the Space key for toggling functionality.

Answer №8

The CSS Basic User Interface Module Level 4 introduces a new feature called accent-color, making it easier to customize styles:

input {
    accent-color: rebeccapurple;
}
<input type="checkbox" />

You can specify any CSS color value (e.g. named, hex code) for the accent-color property, and it will be applied accordingly.

Currently supported in Chrome (v93+), Edge (v93+), Firefox (v92+), Opera (v79+), and Safari (v15.4+).

Note: Some browsers may not fully support alpha channel values via rgba(). Refer to MDN Browser Compatibility for details.

Answer №9

By using pure CSS without any fancy :before or :after tricks, no transforms needed, you have the ability to disable the default appearance and then customize it with an inline background image as demonstrated in the code snippet below. This method is compatible with Chrome, Firefox, Safari, and the latest version of Edge (Chromium Edge).

INPUT[type=checkbox]:focus
{
    outline: 1px solid rgba(0, 0, 0, 0.2);
}

INPUT[type=checkbox]
{
    background-color: #DDD;
    border-radius: 2px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 17px;
    height: 17px;
    cursor: pointer;
    position: relative;
    top: 5px;
}

INPUT[type=checkbox]:checked
{
    background-color: #409fd6;
    background: #409fd6 url("") 3px 3px no-repeat;
}
<form>
  <label><input type="checkbox"> I Agree To Terms &amp; Conditions</label>
</form>

Answer №10

Easy-to-use and fully customizable solution

After extensive research and testing, I stumbled upon a simple and highly customizable solution that is easy to implement and modify. This solution offers the following benefits:

  1. No external libraries or files required
  2. No need to insert additional HTML into your page
  3. No necessity to alter checkbox names and IDs

To effortlessly transform the appearance of all checkboxes on your page, simply add the following CSS snippet at the top:

https://i.stack.imgur.com/hclvc.jpg

input[type=checkbox] {
  transform: scale(1.5);
}

input[type=checkbox] {
  width: 30px;
  height: 30px;
  margin-right: 8px;
  cursor: pointer;
  font-size: 17px;
  visibility: hidden;
}

input[type=checkbox]:after,
input[type=checkbox]::after {
  content: " ";
  background-color: #fff;
  display: inline-block;
  margin-left: 10px;
  padding-bottom: 5px;
  color: #00BFF0;
  width: 22px;
  height: 25px;
  visibility: visible;
  border: 1px solid #00BFF0;
  padding-left: 3px;
  border-radius: 5px;
}

input[type=checkbox]:checked:after,
input[type=checkbox]:checked::after {
  content: "\2714";
  padding: -5px;
  font-weight: bold;
}
<input type="checkbox" id="checkbox1" />
<label for="checkbox1">Checkbox</label>

Answer №11

Enhance the appearance of checkboxes with a clever technique utilizing the label element as illustrated below:

.checkbox > input[type=checkbox] {
  visibility: hidden;
}

.checkbox {
  position: relative;
  display: block;
  width: 80px;
  height: 26px;
  margin: 0 auto;
  background: #FFF;
  border: 1px solid #2E2E2E;
  border-radius: 2px;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
}

.checkbox:after {
  position: absolute;
  display: inline;
  right: 10px;
  content: 'no';
  color: #E53935;
  font: 12px/26px Arial, sans-serif;
  font-weight: bold;
  text-transform: capitalize;
  z-index: 0;
}

.checkbox:before {
  position: absolute;
  display: inline;
  left: 10px;
  content: 'yes';
  color: #43A047;
  font: 12px/26px Arial, sans-serif;
  font-weight: bold;
  text-transform: capitalize;
  z-index: 0;
}

.checkbox label {
  position: absolute;
  display: block;
  top: 3px;
  left: 3px;
  width: 34px;
  height: 20px;
  background: #2E2E2E;
  cursor: pointer;
  transition: all 0.5s linear;
  -webkit-transition: all 0.5s linear;
  -moz-transition: all 0.5s linear;
  border-radius: 2px;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  z-index: 1;
}

.checkbox input[type=checkbox]:checked + label {
  left: 43px;
}
<div class="checkbox">
  <input id="checkbox1" type="checkbox" value="1" />
  <label for="checkbox1"></label>
</div>

Check out this FIDDLE providing an interactive demo of the code above. Please note that some CSS may not work in older browsers, but innovative JavaScript solutions can also be explored!

Answer №12

To circumvent the need for additional markup, you can utilize this method which functions across various platforms except for IE by adjusting the CSS appearance:

input[type="checkbox"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;

  /* Styling checkbox */
  width: 16px;
  height: 16px;
  background-color: red;
}

input[type="checkbox"]:checked {
  background-color: green;
}
<input type="checkbox" />

Answer №13

Recently, I stumbled upon an intriguing solution to the issue at hand.

You can utilize appearance: none; to disable the default styling of the checkbox and then create your own custom style, as detailed here (Example 4).

input[type=checkbox] {
  width: 23px;
  height: 23px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  margin-right: 10px;
  background-color: #878787;
  outline: 0;
  border: 0;
  display: inline-block;
  -webkit-box-shadow: none !important;
  -moz-box-shadow: none !important;
  box-shadow: none !important;
}

input[type=checkbox]:focus {
  outline: none;
  border: none !important;
  -webkit-box-shadow: none !important;
  -moz-box-shadow: none !important;
  box-shadow: none !important;
}

input[type=checkbox]:checked {
  background-color: green;
  text-align: center;
  line-height: 15px;
}
<input type="checkbox">

Unfortunately, support for the appearance property is quite limited across different browsers. Based on my testing, I found that only Opera and Chrome displayed the desired results correctly. However, this method could be the way forward for simplicity until better browser support becomes available or if you specifically target Chrome/Opera.

JSFiddle Demo

"Can I use?" Browser Support Info

Answer №14

My preference lies with utilizing icon fonts like FontAwesome due to their ease of color modification through CSS and excellent scalability on high pixel-density devices. Below is a variant created purely in CSS using similar techniques as the ones mentioned earlier.

(The image below is static for visualization; refer to the interactive JSFiddle version.)

Similar to other solutions, this one incorporates the label element with an adjacent span that contains the checkbox character.

span.bigcheck-target {
  font-family: FontAwesome; /* Utilizing an icon font for the checkbox */
}

input[type='checkbox'].bigcheck {
  position: relative;
  left: -999em; /* Hiding the actual checkbox */
}

input[type='checkbox'].bigcheck + span.bigcheck-target:after {
  content: "\f096"; /* Represents an open square (fa-square-o) in FontAwesome */
}

input[type='checkbox'].bigcheck:checked + span.bigcheck-target:after {
  content: "\f046"; /* Denotes a checked box (fa-check-square-o) in FontAwesome */
}

/* ==== Optional - custom colors and padding for aesthetic appeal === */
body {
  background-color: #2C3E50;
  color: #D35400;
  font-family: sans-serif;
  font-weight: 500;
  font-size: 4em; /* Adjust size as needed */
}

span.bigcheck {
  display: block;
  padding: 0.5em;
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />

<span class="bigcheck">
  <label class="bigcheck">
    Cheese
    <input type="checkbox" class="bigcheck" name="cheese" value="yes" />
    <span class="bigcheck-target"></span>
  </label>
</span>

Check out the JSFiddle link for further details.

Answer №15

Here's How I Solved It

input[type="checkbox"] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: 0;
  background: lightgray;
  height: 16px;
  width: 16px;
  border: 1px solid white;
}

input[type="checkbox"]:checked {
  background: #2aa1c0;
}

input[type="checkbox"]:hover {
  filter: brightness(90%);
}

input[type="checkbox"]:disabled {
  background: #e6e6e6;
  opacity: 0.6;
  pointer-events: none;
}

input[type="checkbox"]:after {
  content: '';
  position: relative;
  left: 40%;
  top: 20%;
  width: 15%;
  height: 40%;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  display: none;
}

input[type="checkbox"]:checked:after {
  display: block;
}

input[type="checkbox"]:disabled:after {
  border-color: #7b7b7b;
}
<input type="checkbox><br>
<input type="checkbox" checked><br>
<input type="checkbox" disabled><br>
<input type="checkbox" disabled checked><br>

Answer №16

To ensure that your styles are applied properly without any default styling, you can utilize the appearance: none property on modern browsers:

input[type=checkbox] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: inline-block;
  width: 2em;
  height: 2em;
  border: 1px solid gray;
  outline: none;
  vertical-align: middle;
}

input[type=checkbox]:checked {
  background-color: blue;
}

Answer №17

Check out this effortless CSS solution that doesn't require any jQuery or JavaScript.

I've opted for FontAwseome icons in this example, but feel free to use any image of your choice.

input[type=checkbox] {
  display: inline-block;
  font-family: FontAwesome;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  visibility: hidden;
  font-size: 14px;
}

input[type=checkbox]:before {
  content: @fa-var-square-o;
  visibility: visible;
  /*font-size: 12px;*/
}

input[type=checkbox]:checked:before {
  content: @fa-var-check-square-o;
}

Answer №18

After conducting some research, I have found a simple method for styling checkboxes. You can achieve this by utilizing the :after and :checked:after CSS selectors to customize the design according to your preferences.

body{
  background: #DDD;
}
span{
  margin-left: 30px;
}
input[type=checkbox] {
    cursor: pointer;
    font-size: 17px;
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    transform: scale(1.5);
}

input[type=checkbox]:after {
    content: " ";
    background-color: #fff;
    display: inline-block;
    color: #00BFF0;
    width: 14px;
    height: 19px;
    visibility: visible;
    border: 1px solid #FFF;
    padding: 0 3px;
    margin: 2px 0;
    border-radius: 8px;
    box-shadow: 0 0 15px 0 rgba(0,0,0,0.08), 0 0 2px 0 rgba(0,0,0,0.16);
}

input[type=checkbox]:checked:after {
    content: "\2714";
    display: unset;
    font-weight: bold;
}
<input type="checkbox"> <span>Select Text</span>

Answer №19

Revamp the look of checkboxes using only CSS, no need for JavaScript or HTML edits:

.form input[type="checkbox"]:before {
  display: inline-block;
  font: normal normal normal 14px/1 FontAwesome;
  font-size: inherit;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  content: "\f096";
  opacity: 1 !important;
  margin-top: -25px;
  appearance: none;
  background: #fff;
}

.form input[type="checkbox"]:checked:before {
  content: "\f046";
}

.form input[type="checkbox"] {
  font-size: 22px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" />

<form class="form">
  <input type="checkbox" />
</form>

Answer №20

Wow! Dealing with all these workarounds has made me realize that styling the HTML checkbox can be quite challenging.

Just a heads up, this isn't a CSS solution. I thought I'd share the workaround I came up with in case it could be useful to someone else.


My solution involved using the canvas element in HTML5.

The benefit of this approach is that you can avoid using external images and potentially save on bandwidth.

The downside is that if a browser is unable to render the canvas correctly, there's no fallback option. However, this might not be as big of an issue in 2017.

Update

I found the original code to be quite messy, so I decided to give it a revamp.

Object.prototype.create = function(args){
    var newObj = Object.create(this);

    newObj.constructor(args || null);

    return newObj;
}

var Checkbox = Object.seal({
    width: 0,
    height: 0,
    state: 0,
    document: null,
    parent: null,
    canvas: null,
    ctx: null,

    /*
     * args:
     * name      default             desc.
     *
     * width     15                  width
     * height    15                  height
     * document  window.document     explicit document reference
     * target    this.document.body  target element to insert checkbox into
     */
    constructor: function(args){
        if(args === null)
            args = {};

        this.width = args.width || 15;
        this.height = args.height || 15;
        this.document = args.document || window.document;
        this.parent = args.target || this.document.body;
        this.canvas = this.document.createElement("canvas");
        this.ctx = this.canvas.getContext('2d');

        this.canvas.width = this.width;
        this.canvas.height = this.height;
        this.canvas.addEventListener("click", this.ev_click(this), false);
        this.parent.appendChild(this.canvas);
        this.draw();
    },

    ev_click: function(self){
        return function(unused){
            self.state = !self.state;
            self.draw();
        }
    },

    draw_rect: function(color, offset){
        this.ctx.fillStyle = color;
        this.ctx.fillRect(offset, offset,
                this.width - offset * 2, this.height - offset * 2);
    },

    draw: function(){
        this.draw_rect("#CCCCCC", 0);
        this.draw_rect("#FFFFFF", 1);

        if(this.is_checked())
            this.draw_rect("#000000", 2);
    },

    is_checked: function(){
        return !!this.state;
    }
});

Check out the live demo here.

The updated version utilizes prototypes and differential inheritance to create an efficient system for generating checkboxes. To create a checkbox:

var myCheckbox = Checkbox.create();

This will instantly add the checkbox to the DOM and set up the events. To check if a checkbox is ticked:

myCheckbox.is_checked(); // Returns true if checked, otherwise false

It's also worth noting that I eliminated the loop.

Update 2

In my previous update, I forgot to mention that utilizing the canvas offers more benefits than just customizing the checkbox appearance. You can even create checkboxes with multiple states, if desired.

Object.prototype.create = function(args){
    var retObj = Object.create(this);

    retObj.constructor(args || null);

    return retObj;
}

Object.prototype.extend = function(newObj){
    var oldObj = Object.create(this);

    for(property in newObj)
        oldObj[property] = newObj[property];

    return Object.seal(oldObj);
}

var Checkbox = Object.seal({
    width: 0,
    height: 0,
    state: 0,
    document: null,
    parent: null,
    canvas: null,
    ctx: null,

    /*
     * args:
     * name      default             desc.
     *
     * width     15                  width
     * height    15                  height
     * document  window.document     explicit document reference
     * target    this.document.body  target element to insert checkbox into
     */
    constructor: function(args){
        if(args === null)
            args = {};

        this.width = args.width || 15;
        this.height = args.height || 15;
        this.document = args.document || window.document;
        this.parent = args.target || this.document.body;
        this.canvas = this.document.createElement("canvas");
        this.ctx = this.canvas.getContext('2d');

        this.canvas.width = this.width;
        this.canvas.height = this.height;
        this.canvas.addEventListener("click", this.ev_click(this), false);
        this.parent.appendChild(this.canvas);
        this.draw();
    },

    ev_click: function(self){
        return function(unused){
            self.state = (self.state + 1) % 3;
            self.draw();
        }
    },

    draw_rect: function(color, offsetX, offsetY){
        this.ctx.fillStyle = color;
        this.ctx.fillRect(offsetX, offsetY,
                this.width - offsetX * 2, this.height - offsetY * 2);
    },

    draw: function(){
        this.draw_rect("#CCCCCC", 0, 0);
        this.draw_rect("#FFFFFF", 1, 1);
        this.draw_state();
    },

    draw_state: function(){
        if(this.is_checked())
            this.draw_rect("#000000", 2, 2);

        if(this.is_partial())
            this.draw_rect("#000000", 2, (this.height - 2) / 2);
    },

    is_checked: function(){
        return this.state == 1;
    },

    is_partial: function(){
        return this.state == 2;
    }
});

var Checkbox3 = Checkbox.extend({
    ev_click: function(self){
        return function(unused){
            self.state = (self.state + 1) % 3;
            self.draw();
        }
    },

    draw_state: function(){
        if(this.is_checked())
            this.draw_rect("#000000", 2, 2);

        if(this.is_partial())
            this.draw_rect("#000000", 2, (this.height - 2) / 2);
    },

    is_partial: function(){
        return this.state == 2;
    }
});

I made slight adjustments to the previous Checkbox implementation to make it more versatile, allowing for extension with a 3-state checkbox. Check out the demo here. As you can see, it already offers more functionality than a standard checkbox.

When deciding between JavaScript and CSS, consider these points.

Original Code

Live Demo

First, prepare a canvas:

var canvas = document.createElement('canvas'),
    ctx = canvas.getContext('2d'),
    checked = 0; // The state of the checkbox
canvas.width = canvas.height = 15; // Set the width and height of the canvas
document.body.appendChild(canvas);
document.body.appendChild(document.createTextNode(' Togglable Option'));

Next, establish a method for updating the canvas automatically:

(function loop(){
  // Draws a border
  ctx.fillStyle = '#ccc';
  ctx.fillRect(0,0,15,15);
  ctx.fillStyle = '#fff';
  ctx.fillRect(1, 1, 13, 13);
  // Fills in canvas if checked
  if(checked){
    ctx.fillStyle = '#000';
    ctx.fillRect(2, 2, 11, 11);
  }
  setTimeout(loop, 1000/10); // Refresh 10 times per second
})();

Lastly, make it interactive. Fortunately, it's straightforward:

canvas.onclick = function(){
  checked = !checked;
}

This may cause issues in IE due to its peculiar event handling model in JavaScript.


I hope this guide proves helpful to someone; it certainly met my requirements.

Answer №21

Enhancing Checkbox Styling with SCSS / SASS

A Fresh and Improved Approach

If you are familiar with SCSS (or can easily switch to SASS), this method will provide a modern solution for styling your checkboxes. The idea is to create an element adjacent to the checkbox that can be styled according to the checkbox state. Below is the code snippet to achieve this:

label.checkbox {
  input[type="checkbox"] {
    visibility: hidden;
    display: block;
    height: 0;
    width: 0;
    position: absolute;
    overflow: hidden;

    &:checked + span {
      background: $accent;
    }
  }

  span {
    cursor: pointer;
    height: 15px;
    width: 15px;
    border: 1px solid $accent;
    border-radius: 2px;
    display: inline-block;
    transition: all 0.2s $interpol;
  }
}
<label class="checkbox">
    <input type="checkbox" />
    <span></span>
    Label text
</label>

Answer №22

Check out this minimal and elegant template:

input[type=checkbox] {
  cursor: pointer;
}

input[type=checkbox]:checked:before {
  content: "\2713";
  background: #fffed5;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
  font-size: 20px;
  text-align: center;
  line-height: 8px;
  display: inline-block;
  width: 13px;
  height: 15px;
  color: #00904f;
  border: 1px solid #cdcdcd;
  border-radius: 4px;
  margin: -3px -3px;
  text-indent: 1px;
}

input[type=checkbox]:before {
  content: "\202A";
  background: #ffffff;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
  font-size: 20px;
  text-align: center;
  line-height: 8px;
  display: inline-block;
  width: 13px;
  height: 15px;
  color: #00904f;
  border: 1px solid #cdcdcd;
  border-radius: 4px;
  margin: -3px -3px;
  text-indent: 1px;
}
<input type="checkbox" checked="checked">checked1<br>
<input type="checkbox">unchecked2<br>
<input type="checkbox" checked="checked" id="id1">
<label for="id1">checked2+label</label><br>
<label for="id2">unchecked2+label+rtl</label>
<input type="checkbox" id="id2">
<br>

https://jsfiddle.net/rvgccn5b/

Answer №23

One approach that I find to be quite simple is to style a label element and hide the associated checkbox.

Here's how you can achieve this using HTML:

<input type="checkbox" id="first" />
<label for="first">&nbsp;</label>

For styling with CSS, you can use the following code:

checkbox {
  display: none;
}

checkbox + label {
  /* Style for unchecked checkbox */
  width: 16px;
  height: 16px;
}

checkbox::checked + label,
label.checked {
  /* Style for checked checkbox */
}

Even though the checkbox is hidden, it remains accessible and its value will be included when submitting a form. In older browsers, you may need to utilize JavaScript to toggle the "checked" class on the label, as older versions of Internet Explorer do not support ::checked on the checkbox.

Answer №24

No need for JavaScript or jQuery.

Easily update the style of your checkboxes.

input[type="checkbox"] {
  display: none;
  border: none !important;
  box-shadow: none !important;
}

input[type="checkbox"] + label span {
  background: url("https://i.ibb.co/mG7QRYw/62a9b364a056b98f7e02705a-checkboxunselected.png");
  width: 24px;
  height: 24px;
  display: inline-block;
  vertical-align: middle;
  background-size: 100%;
}

input[type="checkbox"]:checked + label span {
  background: url(https://svgur.com/i/upi.svg);
  width: 24px;
  height: 24px;
  vertical-align: middle;
  background-size: 100%;
}
<input type="checkbox" id="option" />
<label for="option"> <span></span> Click here </label>

Check out this JSFiddle link

Answer №25

Check out this updated design featuring subtle animations and customizable styles:

.checkbox {
    position: relative;
    width: 20px;
    height: 20px;
    -webkit-appearance: none;
    -moz-appearance: none;
    -o-appearance: none;
    appearance: none;
    background: transparent;
    border: 2px solid #7C7A7D;
    border-radius: 5px;
    margin: 0;
    outline: none;
    transition: 0.5s ease;
    opacity: 0.8;
    cursor: pointer;
}


.checkbox:checked {
    border-color: #7C7A7D;
    background-color: #7C7A7D;
}


.checkbox:checked:before {
   position: absolute;
   left: 2px;
   top: -4px;
   display: block;
   content: '\2713';
   text-align: center;
   color: #FFF;
   font-family: Arial;
   font-size: 14px;
   font-weight: 800;
}


.checkbox:hover {
   opacity: 1.0;
   transform: scale(1.05);
}

Answer №26

Styling Custom Checkbox Using CSS (Specifically for WebKit Browsers like Chrome, Safari, and Mobile browsers)

<input type="checkbox" id="cardAccptance" name="cardAccptance" value="Yes">
<label for="cardAccptance" class="bold"> Save Card for Future Use</label>

CSS:

    /* Styling the custom checkbox */
    
    .checkbox-cu {
        display: block;
        position: relative;
        padding-left: 35px;
        margin-bottom: 0;
        cursor: pointer;
        font-size: 16px;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    }
    
    
    /* Hiding the default browser's checkbox */
    
    .checkbox-cu input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }
    
    
    /* Creating a customized checkbox */
    
    .checkmark {
        position: absolute;
        top: 4px;
        left: 0;
        height: 20px;
        width: 20px;
        background-color: #eee;
        border: 1px solid #999;
        border-radius: 0;
        box-shadow: none;
    }
    
    
    /* Adding grey background color on mouse-over */
    
    .checkbox-cu:hover input~.checkmark {
        background-color: #ccc;
    }
    
    
    /* Applying blue background when checkbox is checked */
    
    .checkbox-cu input:checked~.checkmark {
        background-color: transparent;
    }
    
    
    /* Creating the checkmark/indicator (hidden when not checked) */
    
    .checkmark:after {
        content: "";
        position: absolute;
        display: none;
    }
    
    
    /* Showing the checkmark when checked */
    
    .checkbox-cu input:checked~.checkmark:after {
        display: block;
    }
    
    
    /* Styling the checkmark/indicator */
    
    .checkbox-cu .checkmark::after {
        left: 7px;
        top: 3px;
        width: 6px;
        height: 9px;
        border: solid #28a745;
        border-width: 0 2px 2px 0;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        z-index: 100;
    }

Answer №27

Utilizing Materialize alongside a personalized stylesheet can help you create an effect similar to the following:

CSS snippet

.custom_checkbox[type="checkbox"]:checked + span:not(.lever)::before {
  border: 2px solid transparent;
  border-bottom: 2px solid #ffd600;
  border-right: 2px solid #ffd600;
  background: transparent;
}

HTML snippet

<label>
    <input type="checkbox" class="custom_checkbox" />
    <span>Text</span>
</label>

Live Example

JSFiddle demo

Answer №28

Discovering this technique made it possible for me to customize the color of checkboxes

input[type=checkbox] {
  accent-color: red;
}

This method can also be applied to radio buttons.

Answer №29

This method is the most straightforward and allows you to select which checkboxes will have this particular style applied.

CSS:

.check-box input {
  display: none;
}

.check-box span:before {
  content: ' ';
  width: 20px;
  height: 20px;
  display: inline-block;
  background: url("unchecked.png");
}

.check-box input:checked + span:before {
  background: url("checked.png");
}

HTML:

<label class="check-box">
  <input type="checkbox">
  <span>Checkbox Label Text</span>
</label>

Answer №30

Presented here is a CSS/HTML-only version, completely void of jQuery or JavaScript dependency. The HTML structure is simple and clean, accompanied by concise CSS styling.

You can view the JSFiddle demonstration below:

http://jsfiddle.net/v71kn3pr/

Below is the HTML code snippet:

<div id="myContainer">
    <input type="checkbox" name="myCheckbox" id="myCheckbox_01_item" value="red" />
    <label for="myCheckbox_01_item" class="box"></label>
    <label for="myCheckbox_01_item" class="text">I accept the Terms of Use.</label>
</div>

Here is the corresponding CSS markup:

#myContainer {
    outline: black dashed 1px;
    width: 200px;
}
#myContainer input[type="checkbox"][name="myCheckbox"] {
    display: none;
}
/* Additional CSS rules go here */

This HTML/CSS format can be customized to accommodate individual checkboxes or radio buttons, as well as groups of them. Moreover, it allows for checkbox selections via label clicks, ensuring seamless form functionality across various platforms including PHP, ASP.NET, JavaServer Faces, and ColdFusion.

Similar questions

If you have not found the answer to your question or you are interested in this topic, then look at other similar questions below or use the search

What could be the reason that the style tag present in this SVG is not impacting any of the elements?

My SVG file consists of a single element with a fill set to red: <svg width="100" height="60" viewBox="0 0 100 60" fill="none" xmlns="http://www.w3.org/2000/svg"> <path fill="red" d=&qu ...

Integrating additional youngsters into the HTML DOM using Angular.js

I am working with a block of HTML that looks like this: <div id="parent"> <div id="child_1"></div> <div id="child_2"></div> <div id="child_3"></div> <div id="child_4"></div> </div> ...

Concealing axis lines within the initial circular grid or opting not to include them

Is there a way to incorporate some whitespace within the center circle of the radar chart? I'm aiming for the axis to commence at 1 radius (the initial circular line) or perhaps have the stoke set to 0 for the primary radius. Any assistance would be g ...

The parameter type 'Event' cannot be assigned to the argument type

edit-category-component.html: <custom-form-category *ngIf="model" [model]="model" (onSaveChanges)="handleChanges($event)"></custom-form-category> <mat-loader *ngIf="!model"></mat-loader> edi ...

What is the best way to display a bitmap image in a Div, Span, Label, etc. on an Asp.Net page without using a Handler?

I am looking to display a bitmap image within a Div element using code behind. I prefer not to use a handler for this task. Here is an example of what I would like to achieve: div.InnerHtml = BitmapImage; ...

Refrain from engaging with "disabled" table rows to prevent user interaction

I have an HTML table with certain rows marked as 'disabled'. To make this clear to the user, I decided to apply a blur filter to the tr, resulting in a table that looks like this: https://i.stack.imgur.com/GcX67.png NOTE: You can view a live ex ...

Tips for inputting information without redundancy after selecting a specific designation

I'm experiencing a challenge with this code as it repeats when already chosen. My goal is to add data in the database once something has been selected. When I click on spin, the randomizer will choose a name and update their status to "done". Subsequ ...

Increasing the level of CSS list counters

HTML <ol> <li>item1 <ol> <li>item2</li> </ol> </li> <li>item1 <ol> <li>item2</li> <li>item3</li> </ol> </li> </ol> SC ...

Using -webkit-hyphens: auto in Safari does not function properly when the width is set to auto

I have a situation with an h3 element where I am unsure of its width. As a result, the width is set to auto by default. However, I need the text inside this element to have hyphenation applied to it. This h3 element is within a flex container along with an ...

Position the image in the center of the div both horizontally and vertically

At the moment, I have a header division with two sub-divisions called header-top and header-bottom. I am attempting to position my logo in the top-header section and align it both vertically and horizontally. The logo is aligning correctly horizontally, bu ...

Table Dimensions Dream Weaver

After creating a basic PHP webpage using Dream Weaver CS5 Version 11.0 Build 4964, I encountered an issue. My webpage is structured with a table containing 10 rows, each row consisting of a single cell. Within each table cell, there is a nested table tha ...

Tips for highlighting HTML syntax within JavaScript strings in Sublime Text

Is there a Sublime package available for syntax highlighting HTML within JavaScript strings specifically? (Please note that the inquiry pertains to highlighting HTML within JS strings only, not general syntax highlighting.) Currently, I am developing Ang ...

Halt the execution of a function upon clicking a div element

I'm currently working on a function that needs to be stopped when a div with the class "ego" is clicked. This function toggles the visibility of the header based on the scroll position and should only run by default. Below is the code snippet: $("#e ...

Initiating a Page with Dynamic Modal Window according to Backend Exigencies

Dear experts, can you help me with a problem? I want to implement a modal window on an vb.aspx page if a specific condition from the codebehind query is true. How can I achieve this? Thank you! ...

The inclusion of the <div> tag disrupts the functionality of the Material UI Grid

While attempting to enclose my element within a <div> that is nested inside the <Grid>, I realized that this was causing the <Grid> layout to break! Surprisingly, when I tried the same approach with Bootstrap grid system, this issue did n ...

Tips for ensuring that flex-box children can scroll properly

I'm having trouble getting the content to scroll correctly while dealing with nested flex-box structures. Below is my CSS code: html,body,#root{ width:100%; height:100%; padding:0; margin:0; } .flex-fill{ height:100%; width:100%; ...

Error: Syntax mishap detected - Oh dear

Recently, I've been developing a small slideshow / public display for a client using the HTML5 Rock's Slideshow code. Everything was going smoothly until I encountered a DOM Exception 12 - an error related to CSS selectors. Strangely, I couldn&ap ...

Styling a clock with rounded corners using CSS: Border-radius trick

Attempting to craft a analog 12-hour clock using basic CSS properties, I initiated the process by forming a square div of the size 500px. Applying a border-radius of 250px resulted in an aesthetically pleasing circle design. Following this step, I incorpor ...

Storing ng-change event for a checkbox in AngularJS in a valid manner

I have a requirement where I need to handle multiple input checkboxes. The goal is to store the changed checkbox events in an array and then save them when the user submits the changes. <td><input type="checkbox" class="switch" ng-model="each_val ...

Having trouble loading external CSS in HTML?

I have been attempting to load an external CSS file into my current HTML file without success. I have provided images showcasing the code: View the code here See the output here Currently, I am working on Windows and using Aptana Studio 3 as my IDE. ...