在firefox中设置一个复选框样式 - 删除检查和边框

jno*_*tte 16 html css firefox

如何设置firefox中的复选框样式,并使复选标记和边框消失?

http://jsfiddle.net/moneylotion/qZvtY/

CSS:

body { background: black; }
#conditions-form { color: white; }
#conditions-form input[type=checkbox] {
    display:inline-block;
    -webkit-appearance: none;
    -moz-appearance: none;
    -o-appearance:none;
    appearance: none;
    width:19px;
    height:19px;
    background: url('http://demo.somedomain.com/wp-content/themes/themename/images/care-plan-checkbox.gif') no-repeat top left;
    cursor:pointer;
}
#conditions-form input[type=checkbox]:checked {
    background:url('http://demo.somedomain.com/wp-content/themes/themename/images/care-plan-checkbox-checked.gif') no-repeat top left;
}
Run Code Online (Sandbox Code Playgroud)

HTML:

<form id="conditions-form">
    <ul>
        <li>
            <input id="condition3" type="checkbox" name="conditions[condition3]"></input>
            <label class="checkbox" for="condition3">Conditions 3</label>
        </li>
    </ul>
</form>
Run Code Online (Sandbox Code Playgroud)

Joe*_*e50 31

你可以通过<label>标签轻松实现这一目标.只需在复选框周围放置一个标签,然后插入一个将用于自定义样式复选框的虚拟元素.例如:

label.checkbox input[type="checkbox"] {display:none;}
label.checkbox span {
  display:inline-block;
  border:2px solid #BBB;
  border-radius:10px;
  width:25px;
  height:25px;
  background:#C33;
  vertical-align:middle;
  margin:3px;
  position: relative;
  transition:width 0.1s, height 0.1s, margin 0.1s;
}
label.checkbox :checked + span {
  background:#6F6;
  width:27px;
  height:27px;
  margin: 2px;
}
label.checkbox :checked + span:after {
  content: '\2714';
  font-size: 20px;
  position: absolute;
  top: -2px;
  left: 5px;
  color: #99a1a7;
}
Run Code Online (Sandbox Code Playgroud)
<label class="checkbox">
  <input type="checkbox"/>
  <span></span>
  I like cake
</label>
Run Code Online (Sandbox Code Playgroud)


编辑:请注意,某些颜色选择可能会使复选框的状态对于colourblind人不可见.在制作这段代码时,我没有想到这一点,但上面的演示对于R/G colourblind人来说可能是不可见的.在实现这一点时,请记住这一点(例如选择亮/暗颜色,或显示形状上的一些差异)


我使用的样式只是随意的,您可以将其更改为您想要的任何内容.您甚至可以通过::before伪元素切换其中的某些文本,例如我在这里所做的.

我无法打开您在问题中使用的图像网址,但我认为您只需稍微修改一下这些代码就可以包含您想要的任何图像.只需将当前background颜色更改为您要使用的图像URL即可.

注意:这在某些旧版浏览器中不起作用.


Lee*_*ase 15

上面接受的答案很棒,但是对Joeytje50的小提琴的轻微调整允许选中复选框.

使用不透明度0而不是显示无意味着复选框仍然是可列表的,因此可通过键盘访问.

绝对位置将输入复选框放在绘制框的左上角,这意味着您的格式保持整洁.

input[type="checkbox"] {
    opacity: 0;
    position: absolute;
}
input[type="checkbox"] + label {
    text-align:center;
    cursor:pointer;
}
input[type="checkbox"]:focus + label {
    background-color: #ddd;
}
input[type="checkbox"] + label div {
    display:inline-block;
    line-height: 16px;
    font-size: 12px;
    height: 16px;
    width: 16px;
    margin:-0px 4px 0 0;
    border: 1px solid black;
    color: transparent;
}
input[type="checkbox"]:checked + label div {
    color: black;
}
Run Code Online (Sandbox Code Playgroud)
<input type="checkbox" id="c1" name="cc" />
<label for="c1">
    <div>&#x2714;</div>Check Box 1<br />
</label>
<input type="checkbox" id="c12" name="cc" />
<label for="c12">
    <div>&#x2714;</div>Check Box 2<br />
</label>
Run Code Online (Sandbox Code Playgroud)


jno*_*tte 8

这个tutsplus教程解决了我的问题.

input[type="checkbox"] {
  display:none;
}
 
input[type="checkbox"] + label span {
  display:inline-block;
  width:19px;
  height:19px;
  margin:-1px 4px 0 0;
  vertical-align:middle;
  background:url(https://cdn.tutsplus.com/webdesign/uploads/legacy/tuts/391_checkboxes/check_radio_sheet.png) left top no-repeat;
  cursor:pointer;
}
input[type="checkbox"]:checked + label span {
  background:url(https://cdn.tutsplus.com/webdesign/uploads/legacy/tuts/391_checkboxes/check_radio_sheet.png) -19px top no-repeat;
}
Run Code Online (Sandbox Code Playgroud)
<input type="checkbox" id="c1" name="cc" />
<label for="c1"><span></span>Check Box 1</label>
Run Code Online (Sandbox Code Playgroud)

  • 注意[不鼓励仅链接答案](http://meta.stackexchange.com/questions/8231/are-answers-that-just-contain-links-elsewhere-really-good-answers),好像链接消失然后答案变得无用 - 我将编辑此答案以添加相关的HTML + CSS (3认同)