css - 当同级具有可变宽度时,如何使元素填充剩余宽度?

标签 css layout forms

在下面的例子中: enter image description here

我希望文本框填满所有可用空间。问题是下拉宽度无法固定,因为它的元素不是静态的。我想只用 css 解决这个问题(如果可能的话没有 javascript)。

我已经尝试过针对类似问题提出的解决方案,但没有任何运气:(

这是 fiddle :http://jsfiddle.net/ruben_diaz/cAHb8/

这是 html:

<div id="form_wrapper">
    <form accept-charset="UTF-8" action="/some_action" method="post">
        <span class="category_dropdown_container">
            <select class="chosen chzn-done" name="question[category_id]" id="selQJK">
                <option value="1">General</option>
                <option value="2">Fruits</option>
                <option value="3">Ice Creams</option>
                <option value="4">Candy</option>
            </select>
        </span>
        <span class="resizable_text_box">
            <input id="question_text_box" name="question[what]" placeholder="Write a query..." type="text" />
        </span>
        <input name="commit" type="submit" value="Ask!" />
    </form>
</div>

这里是 css:

#form_wrapper {
    border: 1px solid blue;
    width: 600px;
    padding: 5px;
}
form {
    display: inline-block;
    width: 100%;
}
.category_dropdown_container {
}
.resizable_text_box {
    border: 1px solid red;
}
input[type="text"] {
}
input[type="submit"] {
    background-color: lightblue;
    width: 80px;
    float: right;
}

最佳答案

Updated demo (在 IE7/8/9/10、Firefox、Chrome、Safari 中测试正常)

  • float 左右元素。
  • 在 HTML 源代码中,将两个 float 元素都放在前面(这是最重要的部分)。
  • 给中间元素 overflow: hidden; 和隐式宽度 100%
  • 为中间元素中的文本框指定宽度 100%

.category_dropdown_container {
    float: left;
}

input[type="submit"] {
    float: right;
    ...
}

.resizable_text_box {
    padding: 0 15px 0 10px;
    overflow: hidden;
}
.resizable_text_box input {
    width: 100%;
}
<div class="category_dropdown_container">
    <select class="chosen chzn-done" name="question[category_id]" id="selQJK">
        ...
    </select>
</div>

<input name="commit" type="submit" value="Ask!" />

<div class="resizable_text_box">
    <input id="question_text_box" name="question[what]"
           placeholder="Write a query..." type="text" />
</div>

关于css - 当同级具有可变宽度时,如何使元素填充剩余宽度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16241186/

相关文章:

javascript - 如何使用 toDataURL() 将图像作为背景图像与 Canvas 内容一起添加到一个图像中?

javascript - 使用 CSS3 过渡时等效于 jQuery.animate 步进函数

html - 如何将按钮无边距地对齐到文本框的右侧?

CSS Noob 真的可以在布局和定位方面使用一些熟练的帮助

html - 100%高度容器通过绝对定位被推出IE视口(viewport)

javascript - 在 if 语句仍然在页面中显示空对象之后

css - 将按钮转换为超链接

javascript - Express.js + Sequelize + 表单验证

jquery - 添加自定义 URL 参数以及 $(this.form).serialize()

php - Twig : Get value of the entity attached to the form in twig view Symfony