CSS教程

关注公众号 jb51net

关闭
网页制作 > CSS > CSS教程 >

CSS实现元素撑满剩余空间的五种方法

满分观察网友z

CSS实现元素撑满剩余空间的5种方法 🎨

在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求,比如侧边栏+主内容区、头部+内容区+底部等布局。本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点。

Flexbox 方法

📁 详见 ./01-flexbox/index.html

Flexbox 是最现代和推荐的方式。通过设置 flex-grow: 1,元素会自动扩展占据剩余空间。对于垂直布局,配合 height: 0 使用效果更好。

聊天应用布局:

<div class="chat-container">
    <header class="chat-header">
        <img src="avatar.jpg" alt="用户头像">
        <h2>聊天室</h2>
    </header>
    <main class="chat-messages">
        <div class="message received">收到的消息</div>
        <div class="message sent">发送的消息</div>
    </main>
    <footer class="chat-input">
        <input type="text" placeholder="输入消息...">
        <button>发送</button>
    </footer>
</div>
<style>
.chat-container {
    display: flex;
    flex-direction: column;
    height: 100vh;
}
.chat-header {
    height: 60px;
    background: #075e54;
}
.chat-messages {
    flex: 1;
    height: 0; /* 关键属性 */
    overflow-y: auto;
}
.chat-input {
    height: 60px;
    background: #f0f0f0;
}
</style>

实现思路解析:

其他适用场景:

优点:

缺点:

Grid 方法

📁 详见 ./02-grid/index.html

Grid 布局通过 fr 单位或 auto 来分配剩余空间,特别适合复杂的二维布局。

仪表盘布局:

在这里插入图片描述

<div class="dashboard">
    <!-- 状态卡片 -->
    <div class="widget status-card">
        <h3>总访问量</h3>
        <div class="number">1,234,567</div>
    </div>
    <div class="widget status-card">
        <h3>活跃用户</h3>
        <div class="number">45,678</div>
    </div>
    <!-- 大尺寸部件 -->
    <div class="widget large-widget">
        <h3>访问趋势图</h3>
    </div>
</div>
<style>
.dashboard {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 100px 200px;
    gap: 20px;
}
.widget {
    background: white;
    border-radius: 10px;
    padding: 20px;
}
.large-widget {
    grid-column: span 2;
}
/* 响应式布局 */
@media (max-width: 768px) {
    .dashboard {
        grid-template-columns: repeat(2, 1fr);
    }
}
</style>

实现思路解析:

适用场景:

优点:

缺点:

绝对定位方法

📁 详见 ./03-absolute/index.html

使用绝对定位和固定值来计算剩余空间,通过设置 toprightbottomleft 值来精确控制位置。

视频播放器控制层:

<div class="video-container">
    <video poster="thumbnail.jpg">
        <source src="video.mp4" type="video/mp4">
    </video>
    <div class="controls-overlay">
        <div class="top-controls">
            <h2>视频标题</h2>
            <button class="control-button">⚙️</button>
        </div>
        <div class="progress-bar">
            <div class="progress"></div>
        </div>
        <div class="bottom-controls">
            <button class="control-button">▶️</button>
            <div class="time-display">02:30 / 10:00</div>
            <button class="control-button">🔊</button>
        </div>
    </div>
</div>
<style>
.video-container {
    position: relative;
    width: 100%;
    height: 100vh;
}
.controls-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.7) 0%,
        rgba(0,0,0,0) 20%,
        rgba(0,0,0,0) 80%,
        rgba(0,0,0,0.7) 100%
    );
}
.bottom-controls {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    padding: 15px;
}
</style>

实现思路解析:

适用场景:

优点:

缺点:

calc() 方法

📁 详见 ./04-calc/index.html

使用 CSS 的 calc() 函数动态计算尺寸,可以混合使用不同单位进行计算。

多栏布局:

<div class="article-container">
    <h2>等宽三栏布局</h2>
    <div class="three-columns">
        <div class="column">第一栏</div>
        <div class="column">第二栏</div>
        <div class="column">第三栏</div>
    </div>
    <h2>混合宽度布局</h2>
    <div class="mixed-columns">
        <aside class="sidebar">侧边栏</aside>
        <main class="main-content">主内容区</main>
    </div>
</div>
<style>
/* 三栏等宽布局 */
.three-columns {
    display: flex;
    gap: 30px;
}
.three-columns .column {
    width: calc(100% / 3 - 20px);
    /* 减去间距的权重 */
}
/* 混合宽度布局 */
.mixed-columns {
    display: flex;
    gap: 30px;
}
.mixed-columns .sidebar {
    width: 300px;
}
.mixed-columns .main-content {
    width: calc(100% - 330px);
    /* 减去侧边栏宽度和间距 */
}
@media (max-width: 768px) {
    .three-columns,
    .mixed-columns {
        flex-direction: column;
    }
    .three-columns .column,
    .mixed-columns .sidebar,
    .mixed-columns .main-content {
        width: 100%;
    }
}
</style>

实现思路解析:

宽度计算原理:

/* 三栏等宽布局 */
width: calc(100% / 3 - 20px)  /* 总宽度均分减去间距 */
/* 混合布局 */
width: calc(100% - 330px)     /* 总宽度减去固定宽度和间距 */

适用场景:

优点:

缺点:

table 布局方法

📁 详见 ./05-table/index.html

使用 CSS table 布局属性来分配空间,特别适合需要等高列或自动空间分配的场景。

数据表格:

<div class="table-container">
    <div class="data-table">
        <div class="table-header">
            <div class="table-row">
                <div class="table-cell">ID</div>
                <div class="table-cell">项目名称</div>
                <div class="table-cell">进度</div>
                <div class="table-cell">状态</div>
            </div>
        </div>
        <div class="table-body">
            <div class="table-row">
                <div class="table-cell">001</div>
                <div class="table-cell">项目重构</div>
                <div class="table-cell">
                    <div class="progress-bar">
                        <div class="progress" style="width: 75%"></div>
                    </div>
                </div>
                <div class="table-cell">
                    <span class="status">进行中</span>
                </div>
            </div>
        </div>
    </div>
</div>
<style>
.data-table {
    display: table;
    width: 100%;
    border-collapse: collapse;
}
.table-header {
    display: table-header-group;
    background: #f8f9fa;
}
.table-body {
    display: table-row-group;
}
.table-row {
    display: table-row;
}
.table-cell {
    display: table-cell;
    padding: 15px;
    border-bottom: 1px solid #dee2e6;
    vertical-align: middle;
}
/* 列宽设置 */
.table-cell:nth-child(1) { width: 80px; }
.table-cell:nth-child(2) { width: 200px; }
.table-cell:nth-child(3) { width: 200px; }
.table-cell:nth-child(4) { width: 120px; }
</style>

实现思路解析:

适用场景:

最佳实践建议 💡

总结

每种方法都有其适用场景,选择合适的方法要考虑:

建议在实际项目中:

到此这篇关于CSS实现元素撑满剩余空间的五种方法的文章就介绍到这了,更多相关css元素撑满剩余空间内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!