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

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

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

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

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

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

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


当前回答

我还没有完全测试过我的解决方案,但它似乎很有效。

我的HTML很简单:

<label class="checkbox"><input type="checkbox" value="0000">0000 - 0100</label>

然后,我将高度和宽度的所有复选框设置为24px。为了使文本对齐,我使标签的行高度也为24px,并指定垂直对齐:top;像这样:

编辑:IE测试后,我添加了垂直对齐:底部;并更改了标签的CSS。你可能会发现你需要一个有条件的IE css案例来整理填充-但是文本和框是内联的。

输入[type=“checkbox”]{宽度:24px;高度:24px;垂直对齐:底部;}标签复选框{垂直对齐:顶部;线条高度:24px;边距:2px 0;显示:块;高度:24px;}<label class=“checkbox”><input type=“checkbox“value=“0000”>0000-0100</label><label class=“checkbox”><input type=“checkbox”value=“0100”>0100-0200</label><label class=“checkbox”><input type=“checkbox”value=“0200”>0200-0300</label><label class=“checkbox”><input type=“checkbox”value=“0300”>0300-0400</label>

如果有人发现这不起作用,请告诉我。以下是它的实际操作(在Chrome和IE中-道歉,因为屏幕截图是在视网膜上拍摄的,并使用了IE的类似物):

其他回答

<表单><div><label style=“display:inline block”><input style=“vertical align:middle”type=“checkbox”/>标签文本</span></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方法,这些方法在我看来是非常古老的,而且是通用的。

我认为这是最简单的方法

输入{位置:相对;顶部:1px;}<表单><div><label><input-type=“checkbox”/>标签文本</label></div><表单>

警告这个答案太老了,在现代浏览器上不起作用。

我不是这个答案的海报,但在写这篇文章时,这是迄今为止在正面和负面投票中投票最多的答案(+1035-17),它仍然被标记为接受答案(可能是因为问题的原始海报是写这个答案的人)。

正如评论中多次指出的那样,这个答案在大多数浏览器上都不起作用了(自2013年以来似乎一直无法做到这一点)。


经过一个多小时的调整、测试和尝试不同风格的标记,我想我可能有一个不错的解决方案。该特定项目的要求如下:

输入必须在自己的线路上。复选框输入需要在所有浏览器中与标签文本垂直对齐(如果不相同)。如果标签文本换行,则需要缩进(因此复选框下面没有换行)。

在我做出任何解释之前,我只给你代码:

标签{显示:块;向左填充:15px;文本缩进:-15px;}输入{宽度:13px;高度:13px;填充:0;边距:0;垂直对齐:底部;位置:相对;顶部:-1px;*溢出:隐藏;}<表单><div><label><input-type=“checkbox”/>标签文本</label></div></form>

这里是JSFiddle中的工作示例。

这段代码假设您使用的是类似于EricMeyer的重置,它不会覆盖表单输入边距和填充(因此在输入CSS中设置边距和填充重置)。显然,在实际环境中,您可能会嵌套/覆盖支持其他输入元素的内容,但我希望保持简单。

需要注意的事项:

*溢出声明是一个内联IE黑客(星属性黑客)。IE 6和7都会注意到它,但Safari和Firefox会适当地忽略它;只是为了简单起见使用它。据我所知,在浏览器中唯一一致的垂直对齐语句是垂直对齐:底部。在Safari、Firefox和IE中,设置此项并相对向上定位的行为几乎相同,只有一两个像素的差异。使用对齐的主要问题是IE在输入元素周围留下了一堆神秘的空间。它不是填充或边距,它是该死的持久性。在复选框上设置一个宽度和高度,然后溢出:由于某种原因隐藏,会切断额外的空间,并允许IE的定位与Safari和Firefox非常相似。根据您的文本大小,您无疑需要调整相对位置、宽度、高度等,以使内容看起来正确。

除了今天早上我在做的项目之外,我还没有在其他项目上尝试过这种特定的技术,所以如果你找到更稳定的方法,一定要闭嘴。


警告这个答案太老了,在现代浏览器上不起作用。

位置:相对;在IE中的z索引和jQuery的slideUp/slideDown等动画存在一些问题。

CSS:

input[type=checkbox], input[type=radio] {
    vertical-align: baseline;
    position: relative;
    top: 3px;
    margin: 0 3px 0 0;
    padding: 0px;
}
input.ie7[type=checkbox], input.ie7[type=radio] {
    vertical-align: middle;
    position: static;
    margin-bottom: -2px;
    height: 13px;
    width: 13px;
}

jQuery:

$(document).ready(function () {
    if ($.browser.msie && $.browser.version <= 7) {
        $('input[type=checkbox]').addClass('ie7');
        $('input[type=radio]').addClass('ie7');
    }
});

样式可能需要根据<label>中使用的字体大小进行调整

PS(秒):我使用ie7js使css在IE6中工作。