我正在努力将标签与我的样式复选框对齐。我正在使用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;
}
结果是标签上的文字直接放在复选框的下方,而不是放在右侧。这是一个截图作为示例:
我的问题很简单。为什么会这样?如何将标签排列在复选框的右侧呢?
答案 0 :(得分:1)
您的文字标签正在推送到切换按钮下方,因为它已设置为显示:阻止。你可以: 1.将其更改为显示:inline-block,它会在右侧将内联文本放在旁边。 2.保持display:block,但是将float:left添加到你的切换中,以便文本出现在它旁边。
您必须根据需要在文本中添加边距/填充;您可能希望将其包装在一个或其他元素中,以便您可以更轻松地设置它。