如何将标签排列在样式复选框的右侧

时间:2014-10-17 00:53:04

标签: html css css3

我正在努力将标签与我的样式复选框对齐。我正在使用this spiffy CSS toggle switch as a styled checkbox。我有以下HTML:

<label>
  <input id="test" class="cmn-toggle cmn-toggle-round" type="checkbox" />
  <label for="test"></label>
  testlabel
</label>

除此之外,我还有以下CSS:

input.cmn-toggle-round + label {
  padding: 2px;
  width: 60px;
  height: 30px;
  background-color: #dddddd;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  -o-border-radius: 30px;
  border-radius: 30px;
}
input.cmn-toggle-round + label:before, input.cmn-toggle-round + label:after {
  display: block;
  position: absolute;
  top: 1px;
  left: 1px;
  bottom: 1px;
  content: "";
}
input.cmn-toggle-round + label:before {
  right: 1px;
  background-color: #f1f1f1;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  -ms-border-radius: 30px;
  -o-border-radius: 30px;
  border-radius: 30px;
  -webkit-transition: background 0.4s;
  -moz-transition: background 0.4s;
  -o-transition: background 0.4s;
  transition: background 0.4s;
}
input.cmn-toggle-round + label:after {
  width: 29px;
  background-color: #fff;
  -webkit-border-radius: 100%;
  -moz-border-radius: 100%;
  -ms-border-radius: 100%;
  -o-border-radius: 100%;
  border-radius: 100%;
  -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  -webkit-transition: margin 0.4s;
  -moz-transition: margin 0.4s;
  -o-transition: margin 0.4s;
  transition: margin 0.4s;
}
input.cmn-toggle-round:checked + label:before {
  background-color: #8ce196;
}
input.cmn-toggle-round:checked + label:after {
  margin-left: 30px;
}

结果是标签上的文字直接放在复选框的下方,而不是放在右侧。这是一个截图作为示例: this is the output

我的问题很简单。为什么会这样?如何将标签排列在复选框的右侧呢?

1 个答案:

答案 0 :(得分:1)

您的文字标签正在推送到切换按钮下方,因为它已设置为显示:阻止。你可以: 1.将其更改为显示:inline-block,它会在右侧将内联文本放在旁边。 2.保持display:block,但是将float:left添加到你的切换中,以便文本出现在它旁边。

您必须根据需要在文本中添加边距/填充;您可能希望将其包装在一个或其他元素中,以便您可以更轻松地设置它。