为什么CSS中的内容如此困难?我想要一个盒子,里面有一个拨动开关,两边的文字都是垂直居中的。
无论我尝试什么,包含文本的div最终都会相对于包含切换开关的div垂直交错。
我已经阅读了十几个关于垂直居中的SO问题...它们似乎都没有适用。这里没有一些有效的原则吗?
小提琴:https://jsfiddle.net/cinerobert/h7g31bqa/
HTML:
<div id="div-yesnotoggle">
<div id="div-notext">No</div>
<div id="div-switch">
<label class="switch">
<input type="checkbox">
<div class="slider round"></div>
</label>
</div>
<div id="div-yestext">
Yes
</div>
</div>
CSS:
#div-yesnotoggle {
border: solid;
width: 160px;
display: inline-block;
}
#div-notext {
padding-top: 10px;
padding-bottom: 10px;
display: inline-block;
border: solid;
width: 40px;
}
#div-switch {
border: solid;
display: inline-block;
width: 60px;
}
#div-yestext {
padding-top: 10px;
padding-bottom: 10px;
display: inline-block;
border: solid;
}
答案 0 :(得分:1)
删除每个元素上的填充并应用于主容器 并在swith上应用vertical-align:middle
检查以下代码段
#div-yesnotoggle {
border: solid;
width: 160px;
display: inline-block;
padding-top: 10px;
padding-bottom: 10px;
}
#div-notext {
display: inline-block;
border: solid;
width: 40px;
}
#div-switch {
border: solid;
display: inline-block;
width: 60px;
vertical-align: middle;
}
#div-yestext {
display: inline-block;
border: solid;
}
.switch {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
}
.switch input {
display: none;
}
.slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: #ccc;
-webkit-transition: .4s;
transition: .4s;
}
.slider:before {
position: absolute;
content: "";
height: 26px;
width: 26px;
left: 4px;
bottom: 4px;
background-color: white;
-webkit-transition: .4s;
transition: .4s;
}
input:checked + .slider {
background-color: #2196F3;
}
input:focus + .slider {
box-shadow: 0 0 1px #2196F3;
}
input:checked + .slider:before {
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
/* Rounded sliders */
.slider.round {
border-radius: 34px;
}
.slider.round:before {
border-radius: 50%;
}
<div id="div-yesnotoggle">
<div id="div-notext">No</div>
<div id="div-switch">
<label class="switch">
<input type="checkbox">
<div class="slider round"></div>
</label>
</div>
<div id="div-yestext">
Yes
</div>
</div>
希望这有帮助
答案 1 :(得分:1)
要使垂直对齐工作,你必须将它应用于所有显示的兄弟姐妹:inline-block;
像这样:
#div-notext {
padding-top: 10px;
padding-bottom: 10px;
display: inline-block;
vertical-align: middle;
border: solid;
width: 40px;
}
#div-switch {
border: solid;
display: inline-block;
vertical-align: middle;
width: 60px;
}
#div-yestext {
padding-top: 10px;
padding-bottom: 10px;
display: inline-block;
vertical-align: middle;
border: solid;
}