CSS3 网格布局(grid-layout)基础知识 - 弹性尺寸的定义单位:fr 简介及实例

本文介绍网格布局中弹性尺寸的概念及其在CSS3中的实现方式,通过实例展示了如何利用fr尺寸单位来创建自适应布局。

网格布局支持弹性尺寸(flex-size),这是一个很好的自适应布局技术。

弹性尺寸使用fr尺寸单位,其来自 "fraction" 或 "fractional unit" 单词的前两个字母,表示整体空间的一部分。

比如下面的CSS规则:

grid-template-columns: 100px 1fr max-content minmax(min-content, 1fr);

表示有4列,第一列100px固定尺寸,第三列 max-content 代表刚好包含元素不溢出不换行的尺寸,剩下的2列都是弹性尺寸。

按照弹性尺寸的计算规则,两者将均分(这两列的弹性系数相等,均为1)剩下的可用空间。


CSS3示范代码:

#grid {
    display: grid;
    width: 100%;
    grid-template-columns: 100px 1fr max-content minmax(min-content, 1fr);
}
#title {
    background-color: lime;
}
#score {
    background-color: yellow;
}
#stats {
    background-color: lime;
}
#message {
    background-color: orange;
}
div {
    height: 80px;
    line-height: 80px;
    text-align: center;
}

HTML代码:

<div id="grid">
    <div id="title">Site Logo</div>
    <div id="score">Slogan</div>
    <div id="stats">User Zone</div>
    <div id="message">Message</div>
</div>


你可以自己试试看:http://wow.techbrood.com/fiddle/33150


by iefreer


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值