假设我有一个这样的html片段:

<div style="width:300px;">
    <label for="MyInput">label text</label>
    <input type="text" id="MyInput" />
</div>

这不是我的确切代码,但重要的是,在固定宽度的容器中,在同一行上有一个标签和一个文本输入。我如何样式的输入,以填补容器的剩余宽度没有包装和不知道标签的大小?


当前回答

这里给出的答案有点过时了。所以,在这里,我使用现代flexbox最简单的解决方案。

.input-container { 显示:flex; } 输入{ flex-grow: 1; margin-left: 5 px; } < div风格= "宽度:300 px;" > < div class = "输入容器”> <label for="MyInput">label text: </label> <input type="text" id="MyInput"/> < / div > < div class = "输入容器”> <label for="MyInput2">长标签文本:</label> <input type="text" id="MyInput2" /> < / div > < / div >

其他回答

你可以试试这个:

div#panel { border:solid; width:500px; height:300px; } div#content { height:90%; background-color:#1ea8d1; /*light blue*/ } div#panel input { width:100%; height:10%; /*make input doesnt overflow inside div*/ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; /*make input doesnt overflow inside div*/ } <div id="panel"> <div id="content"></div> <input type="text" placeholder="write here..."/> </div>

我建议使用Flexbox:

不过,一定要添加适当的供应商前缀! {形式 宽度:400 px; 边框:1px纯黑色; 显示:flex; } 输入{ flex: 2; } 输入,标签{ 保证金:5 px; } <形式方法=“post”> <label for="myInput">样本标签</label> <input type="text" id="myInput" placeholder="Sample input "/> > < /形式

这里给出的答案有点过时了。所以,在这里,我使用现代flexbox最简单的解决方案。

.input-container { 显示:flex; } 输入{ flex-grow: 1; margin-left: 5 px; } < div风格= "宽度:300 px;" > < div class = "输入容器”> <label for="MyInput">label text: </label> <input type="text" id="MyInput"/> < / div > < div class = "输入容器”> <label for="MyInput2">长标签文本:</label> <input type="text" id="MyInput2" /> < / div > < / div >

实现这一目标的最简单方法是:

CSS:

label{ float: left; }

span
{
    display: block;
    overflow: hidden;
    padding-right: 5px;
    padding-left: 10px;
}

span > input{ width: 100%; }

HTML:

<fieldset>
    <label>label</label><span><input type="text" /></span>
    <label>longer label</label><span><input type="text" /></span>
</fieldset>

看起来像:http://jsfiddle.net/JwfRX/

如果你正在使用Bootstrap 4:

<form class="d-flex">
  <label for="myInput" class="align-items-center">Sample label</label>
  <input type="text" id="myInput" placeholder="Sample Input" class="flex-grow-1"/>
</form>

更好的是,使用Bootstrap内置的东西:

  <form>
    <div class="input-group">
      <div class="input-group-prepend">
        <label for="myInput" class="input-group-text">Default</label>
      </div>
      <input type="text" class="form-control" id="myInput">
    </div>
  </form>

https://jsfiddle.net/nap1ykbr/