我正在使用<table>
来布局标准HTML联系表单。我们不讨论使用表的优点,因为HTML不应该是关于表示而是结构(这就是为什么我认为它无论如何都是合理的。)
尽管如此,这里是我正在使用的标记和CSS(由ASP.NET MVC生成):
<table class="fieldTable">
<tbody>
<tr>
<th><label for="Name">Your name</label></th>
<td><input id="Name" name="Name" type="text" value="" /></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<th><label for="EmailAddress">Your e-mail address</label></th>
<td><input id="EmailAddress" name="EmailAddress" type="text" value="" /></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<th><label for="MessageBody">Message</label></th>
<td><textarea cols="30" id="MessageBody" name="MessageBody" rows="6"></textarea></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td><button type="submit"><span>Send Message</span></button></td>
</tr>
</tbody>
</table>
我的CSS:
.fieldTable th {
text-align: right;
font-weight: normal;
vertical-align: top;
padding: 0.25em;
padding-right: 0.5em; }
.fieldTable input,
.fieldTable textarea,
.fieldTable button {
width: 100%; }
input, textarea, button {
border: 1px solid #999;
padding: 0.5em;
border-radius: 5px;
-webkit-box-shadow: 0px 0px 7px 3px #c4c4c4;
box-shadow: 0px 0px 7px 3px #c4c4c4; }
button { background: #DDD; position: relative; }
button:hover { background: #FFF; }
button:active span { position: relative; top: 2px; left: 2px; }
tr { outline: 1px solid blue; }
td { outline: 1px solid red; }
然而它似乎呈现如下:
为什么<button>
元素不能水平填充单元格?
答案 0 :(得分:2)
我认为您可能正在寻找box-sizing,这是确定在计算宽度/高度时是否添加或排除边距/填充的原因。
box-sizing:border-box;
这应该允许您设置百分比宽度/高度,它将填充而不会溢出。
编辑:默认情况下它处于启用状态(如果您检查元素,您将看到浏览器已添加它)。它可以添加到textareas和输入字段中,以使它们与按钮匹配。
如果你看一下你的屏幕截图。输入字段超出了TD,按钮似乎是唯一真正表现的按钮。
答案 1 :(得分:1)
David我看了你的html,并根据它创建了一个jsFiddle。然后我修改了你的CSS以使用你正在寻找的box-sizing property。虽然它可以应用于DOM上的其他对象,但您可能只想将其提取到自己的类中,仅用于textareas。