这是困扰我的CSS小问题之一。

Stack Overflow周围的人如何在浏览器中始终垂直对齐复选框及其标签?

每当我在Safari中正确对齐它们(通常在输入上使用垂直对齐:基线),它们在Firefox和IE中就完全关闭了。

在Firefox中修复它,Safari和IE不可避免地被搞砸了。我每次编写表单时都在这上面浪费时间。

以下是我使用的标准代码:

<表单><div><label><input-type=“checkbox”/>标签文本</label></div></form>

我通常使用埃里克·迈耶的重置,所以表单元素相对来说没有覆盖。期待您提供的任何提示或技巧!


当前回答

所以我知道这已经得到了很多次的回答,但我觉得我有一个比已经提供的解决方案更优雅的方法。不仅有一个优雅的解决方案,还有两个单独的解决方案来满足您的需求。话虽如此,你需要知道和看到的一切都包含在2 JS Fiddle的评论中。


解决方案#1依赖于给定浏览器的本机“复选框”,尽管有一点扭曲。。。它包含在一个div中,该div更易于跨浏览器定位,并带有一个溢出:隐藏以剪切超过1px的拉伸复选框(这样你就看不到FF的丑陋边框)

简单HTML:(按照链接查看带有注释的css,代码块是为了满足stackoverflow)http://jsfiddle.net/KQghJ/

<label><div class="checkbox"><input type="checkbox" /></div> Label text</label>

解决方案#2使用“Checkbox Toggle Hack”来切换DIV的CSS状态,该状态已在浏览器中正确定位,并使用一个简单的精灵设置复选框未选中和选中状态。所有需要的是用所述复选框切换哈克调整背景位置。在我看来,这是一个更优雅的解决方案,因为您可以更好地控制复选框和收音机,并可以确保它们在浏览器中看起来相同。

简单HTML:(点击链接查看带有注释的CSS,代码块满足StackOverflow)http://jsfiddle.net/Sx5M2/

<label><input type="checkbox" /><div class="checkbox"></div>Label text</label>

如果有人不同意这些方法,请给我留言,我希望听到一些反馈,说明为什么其他人没有找到这些解决方案,或者如果他们有,为什么我在这里看不到关于这些解决方案的答案?如果有人看到这些方法中的一个失败了,那也很高兴看到,但这些方法已经在最新的浏览器中进行了测试,并且依赖于HTML/CSS方法,这些方法在我看来是非常古老的,而且是通用的。

其他回答

我从来没有这样做的问题:

<form>
  <div>
    <input type="checkbox" id="cb" /> <label for="cb">Label text</label>
  </div>
</form>

所以我知道这已经得到了很多次的回答,但我觉得我有一个比已经提供的解决方案更优雅的方法。不仅有一个优雅的解决方案,还有两个单独的解决方案来满足您的需求。话虽如此,你需要知道和看到的一切都包含在2 JS Fiddle的评论中。


解决方案#1依赖于给定浏览器的本机“复选框”,尽管有一点扭曲。。。它包含在一个div中,该div更易于跨浏览器定位,并带有一个溢出:隐藏以剪切超过1px的拉伸复选框(这样你就看不到FF的丑陋边框)

简单HTML:(按照链接查看带有注释的css,代码块是为了满足stackoverflow)http://jsfiddle.net/KQghJ/

<label><div class="checkbox"><input type="checkbox" /></div> Label text</label>

解决方案#2使用“Checkbox Toggle Hack”来切换DIV的CSS状态,该状态已在浏览器中正确定位,并使用一个简单的精灵设置复选框未选中和选中状态。所有需要的是用所述复选框切换哈克调整背景位置。在我看来,这是一个更优雅的解决方案,因为您可以更好地控制复选框和收音机,并可以确保它们在浏览器中看起来相同。

简单HTML:(点击链接查看带有注释的CSS,代码块满足StackOverflow)http://jsfiddle.net/Sx5M2/

<label><input type="checkbox" /><div class="checkbox"></div>Label text</label>

如果有人不同意这些方法,请给我留言,我希望听到一些反馈,说明为什么其他人没有找到这些解决方案,或者如果他们有,为什么我在这里看不到关于这些解决方案的答案?如果有人看到这些方法中的一个失败了,那也很高兴看到,但这些方法已经在最新的浏览器中进行了测试,并且依赖于HTML/CSS方法,这些方法在我看来是非常古老的,而且是通用的。

简单的解决方案:

<label style="display:block">
  <input style="vertical-align:middle" type="checkbox">
  <span  style="vertical-align:middle">Label</span>
</label>

在Chrome、Firefox、IE9+、Safari和iOS 9中测试+

也许有些人也犯了和我一样的错误?这是。。。我为输入框设置了一个宽度,因为它们大多是“文本”类型,但后来忘记了覆盖复选框的宽度,所以我的复选框试图占据大量多余的宽度,因此很难在旁边对齐标签。

.checkboxlabel {
    width: 100%;
    vertical-align: middle;
}
.checkbox {
    width: 20px !important;
}
<label for='acheckbox' class='checkboxlabel'>
    <input name="acheckbox" id='acheckbox' type="checkbox" class='checkbox'>Contact me</label>

早在IE6(使用类选择器)以及Firefox、Safari和Chrome的最新版本中,提供了可点击的标签和正确的对齐方式

我通常将复选框保留为未标记,然后将其“标签”设置为单独的元素。这是一种痛苦,但复选框及其标签的显示方式(正如您所注意到的)在跨浏览器之间存在很大差异,这是我接近控制所有内容外观的唯一方法。

出于同样的原因,我最终也在winforms开发中这样做。我认为复选框控件的根本问题是它实际上是两个不同的控件:框和标签。通过使用复选框,您可以让控件的实现者来决定这两个元素如何彼此相邻地显示(而且他们总是出错,其中错误=不是您想要的)。

我真的希望有人能更好地回答你的问题。