用CSS隐藏复选框

时间:2016-07-09 20:38:28

标签: html css css3 checkbox display

我是html和css的新手,我正在开发一个项目,我想使用自定义复选框。 我试图通过CSS隐藏带有图像的复选框。如果我不需要,我不想重写html。我使用(display:none;)来覆盖复选框,但这也禁用了我的复选框。有没有办法让我的复选框可用而不显示?

    input[type='checkbox'] 
    {
    display: none;
    }

    input[type='checkbox'] + label
    {
    background: url('/Pictures/checkbox_unchecked.jpg')no-repeat;
    height: 30px;
    width: 30px;
    background-size: 100%;
    display:inline-block;
    padding: 0 0 0 0px;
    }

    input[type='checkbox']:checked + label
    {
    background: url('Pictures/checkbox_checked.jpg') no-repeat;
    height: 50px;
    width: 200px;
    background-size: 100%;
    display:inline-block;
    padding: 0 0 0 0px;
    }

3 个答案:

答案 0 :(得分:3)

您可以将复选框的不透明度设置为0.这仍然可以点击。

示例(在黑色矩形内单击):

#checkbox {
  opacity: 0;
}
#container {
  border: 2px solid black;
  width: 20px;;
}
<div id="container">
  <input type="checkbox" id="checkbox" onclick="alert('hello')"/>
</div>

答案 1 :(得分:2)

&#13;
&#13;
label input {
  opacity: 0;
  width: 0;
  height: 0;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

label span.y {
  display: none;
}

label span.n {
  display: inline;
}

label input:checked ~span.y {
  display: inline;
}

label input:checked ~span.n {
  display: none;
}
&#13;
<label>
  <input type="checkbox" value="1">
  <span class="y">Checked!</span>
  <span class="n">Click me!</span>
</label>
&#13;
&#13;
&#13;

只需将span.yspan.n.更改为您的元素(图片或其他内容)。

答案 2 :(得分:1)

input[type='checkbox'] {
  display: block;
  height: 0;
  width: 0;
  opacity: 0;
  overflow: hidden;
}
input[type='checkbox'] + label {
  background: url('http://lorempixel.com/30/30/') no-repeat;
  height: 30px;
  width: 30px;
  background-size: cover;
  display: inline-block;
}
input[type='checkbox']:checked + label {
  background: url('http://lorempixel.com/50/200/') no-repeat;
  height: 50px;
  width: 200px;
  background-size: cover;
  display: inline-block;
}
<input type="checkbox" id="check" />
<label for="check"></label>