我有下面的CSS和HTML片段正在呈现。

文本区域 { 边框:1px实体#999999; 宽度:100%; 保证金:5 px 0; 填充:3 px; } <div style="display: block;" id="rulesformitem" class="formitem"> <label for="rules" id="ruleslabel">规则:</label> <textarea cols="2" rows="10" id="rules"> < / div >

问题是文本区域最终比父区域宽8px(边界为2px +填充为6px)。是否有一种方法继续使用边框和填充,但限制文本区域的总大小为父的宽度?


当前回答

让我们考虑一下我们想要实现的最终输出:一个带有边框和填充的填充文本区域,其特征是当单击时,它们将焦点传递到我们的文本区域,以及块元素典型的自动100%宽度的优势。

在我看来,最好的方法是尽可能使用底层解决方案,以达到最大的浏览器支持。 在这种情况下,唯一的HTML可以很好地工作,避免使用Javascript(无论如何我们都喜欢)。

LABEL标签之所以出现在我们的帮助中,是因为它具有这样的行为,并且允许包含它必须指向的输入元素。 它的默认样式是内联元素之一,因此,给标签一个块显示样式,我们可以利用自己的自动100%宽度,包括填充和边框,而内部文本区域没有边框,没有填充和100%宽度。

看看W3C的其他优点,我们可能会注意到:

不需要“for”属性:当LABEL标签包含目标输入时,它会在单击时自动聚焦子输入; 如果已经为文本区域设计了外部标签,则不会发生冲突,因为给定的输入可能有一个或多个标签。

有关更详细的信息,请参阅W3C细节。

简单的例子:

.container { 宽度:400 px; 边界:3 px 固体# f7c; } .textareaContainer { 显示:块; 边框:3px实心38c; 填充:10 px; } textarea { 宽度:100%; 保证金:0; 填充:0; 边框宽度:0; } 身体< > < div class = "容器" > 我是容器 <标签类= " textareaContainer " > <textarea >我是一个带样式边框的填充文本区域 < / >标签 < / div > < /身体>

. textareacontainer元素的padding和border就是我们要赋予textarea的padding和border。试着编辑它们,按照你想要的样式。 我为. textareacontainer元素提供了大而可见的填充和边框,以让您在单击时看到它们的行为。

其他回答

不,CSS不能这样做。这就是微软最初引入另一种可能更实用的盒子模型的原因。最终获胜的盒子模型使得混合百分比和单位不切实际。

我不认为这是可以与你表达填充和边界宽度的百分比的父。

许多CSS格式问题的答案似乎是“添加另一个<div>!”

所以,在这种精神,你有没有尝试添加一个包装div的边界/填充应用,然后把100%宽度的文本区域里面?比如(未经测试):

文本区域 { 宽度:100%; } .textwrapper { 边框:1px实体#999999; 保证金:5 px 0; 填充:3 px; } <div style="display: block;" id="rulesformitem" class="formitem"> <label for="rules" id="ruleslabel">规则:</label> <div class=" texttwrapper "><textarea cols="2" rows="10" id="rules"/></div> < / div >

这个表hack代码为我工作在所有浏览器从IE8+

<td>
    <textarea style="width:100%" rows=3 name="abc">Modify width:% accordingly</textarea>
</td>

如果你不太介意填充的宽度,这个解决方案实际上会保持填充的百分比。

textarea
{
    border:1px solid #999999;
    width:98%;
    margin:5px 0;
    padding:1%;
}

不完美,但你会得到一些填充和宽度加起来是100%,所以这一切都很好

我正在寻找一个内联样式的解决方案,而不是CSS解决方案,这是最好的我可以为一个响应式文本区域:

<div style="width: 100%; max-width: 500px;">
  <textarea style="width: 100%;"></textarea>
</div>