电话
400 9058 355
浮动布局中中间列自适应的本质是「减法计算」,即用父容器宽度减去左右固定列宽度;需显式计算而非设width:auto,且必须清除浮动防止高度塌陷。
浮动布局下实现中间

width: auto(这在浮动中无效),而是手动算出它的宽度:用父容器宽度减去左右固定列的宽度。浏览器不会自动帮你做这个减法,必须显式写死或用 CSS 表达式。
实际项目中主要靠以下方式之一完成「减法」,选哪种取决于兼容性要求和维护成本:
200px + 150px),父容器也固定宽。中间列写 width: 650px(假设父容器 1000px)——最简单,但无响应性width: calc(100% - 200px - 150px)。注意括号内运算符两侧必须有空格,否则部分旧版 Safari 会解析失败margin-left 和 margin-right 留出左右空间。此时中间列块级元素会自然填满剩余空间,但需确保它没被浮动影响流式行为只要用了 float,父容器大概率会高度塌陷,导致后续内容上移。中间列再怎么算宽也没用——它可能直接掉到父容器外面去了。
overflow: hidden 或伪元素 ::after { content: ""; display: table; clear: both; }
height: 100% 让中间列撑高——浮动布局中百分比高度需要所有祖先都有明确高度,实操中几乎不可行.container {
overflow: hidden; /* 触发BFC,防止塌陷 */
}
.left {
float: left;
width: 200px;
}
.right {
float: right;
width: 150px;
}
.middle {
margin-left: 200px;
margin-right: 150px;
/* 不浮动,靠margin留空后自然占满剩余宽度 */
}中间列自适应在浮动布局里从来不是“智能适配”,而是靠人算出来的静态余量;一旦左右列变成百分比或响应式变化,calc() 就得配合媒体查询反复调整,这时候就该考虑放弃浮动,转向 flex 或 grid 了。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...