minmax()函数如何工作

栏目: CSS · 发布时间: 7年前

内容简介:minmax()函数如何工作

CSS Grid Layout规范 中的 minmax() 函数是一个非常有用的新特性。这个函数能够让我们用最简单的CSS控制网格轨道的大小。这个函数包括一个最小值和最大值。

minmax()函数

minmax() 函数接受两个参数,一个最小值和一个最大值。

minmax(min, max)

如果定义的最大值小于最小值,它将会被忽略,函数会被视为只设置了一个最小值。

minmax() 函数接受六种类型的值:

  • 长度值 <length>
  • 百分比值
  • 弹性值
  • max-content
  • min-content
  • auto

接下来通过实例来分别介绍这六种类型值的实际使用现象。

Length

minmax() 函数使用长度( length )也许是最简单的值,就是一个基本的长度。例如,这有一个简单的一行三列的网格。

minmax()函数如何工作

使用 minmax() 函数,可以指定网格中黄色单元格宽度保持在 100px200px 之间。随着浏览器窗口的大小改变,这绝对值将会改变,但总是在这两个范围之内变化。

.grid {
    display: grid;
    grid-template-columns: minmax(100px, 200px) 1fr 1fr;
}

minmax()函数如何工作

网格的第二列和第三列的收缩和扩展会根据网格容器剩余空间进行填充,但网格的第一列总是保持在 100px200px 之间。

Percentage

minmax() 函数除了可以使用 length 单位之外也可以使用百分比单位。如果我们把黄色网格设置了最大值为 50% 。表示黄色网格最大宽度是网格容器宽度的一半,但最大值不会有小于 200px 的值。

minmax()函数如何工作

无论浏览器视窗缩到多小,黄色网格宽度都不会小于 200px 。但是,当网格容器有足够的空间时,黄色网格宽度始终都会是容器宽度的一半。

弹性长度

弹性长度是一个新的单位,它类似于 minmax() 函数,也是CSS Grid Layout中的一个规范。这个长度使用的是 fr 单位,代表网格容器自由空间。例如,假设有一个 100px 宽的网格,这个网格有两个列。一列是固定宽度 20px ,另一列的宽度是 1fr 。那么第二列有效的宽度为 80px ,因为网格内可用的剩余空间是 80px

目前, fr 单位只能作用于 minmax() 函数中的最大值(尽管 规范中有提到过 ,在未来,它可能也可以用于 minmax() 函数的最小值)。回到我们的示例中来,可以指定黄色的网格单元格最小宽度为 200px ,如果最大值设置为 1fr ,当浏览器可用空间大于 200px ,那么最大宽度将会大于 200px 。同样的另外两列的宽度也可以用 1fr

当另外两两也采用了 1fr 时,加上 minmax() 函数中最大值 1fr ,这样整个可用空间分成三等份,当其宽度大于 200px 时,那么其值才会用于黄色网格,如果其值小于 200px 时,那么黄色网格的宽度始终会是 200px 。前面也说到过,当 minmax() 函数中的最大值小于最小值时,它将会被忽略。

.grid {
    display: grid;
    grid-template-columns: minmax(200px, 1fr) 1fr 1fr;
}

minmax()函数如何工作

因为视窗有足够大的空间,所以使用 1fr 单位之后,将等分网格列。

max-content

max-content 关键词是一个特殊的值,它代表了单元格“最理想的大小”。网格单元格最小的宽度围绕它的内容。例如,如果单元格的的内容是一个句子,理想的单元格的宽度将是整个名子的长度,无论是什么长度,单元格内容的句子都不会换行。

把之前的示例中黄色的网格的最大值和最小值都设置为 max-content

.grid {
    display: grid;
    grid-template-columns: minmax(max-content, max-content) 1fr 1fr;
}

minmax()函数如何工作

正如我们所见,列的尺寸扩大到整个内容字符串长度。因为最大和最小值都设置了 max-content ,所以列的宽度是一样的。

min-content

min-content 关键词和 max-content 一样,是一种特殊的值。它代表单元格最小宽度,可以不让内容溢出单元格,除非是不可避免的。

使用上面的示例,在 minmax() 函数中的最小值和最大值都设置 min-content ,这个示例可以说明 min-contentmax-content 之间的区别。

.grid {
    display: grid;
    grid-template-columns: minmax(min-content, min-content) 1fr 1fr;
}

minmax()函数如何工作

我们可以看到,单元格的内容使用了最小宽度,将可用空间转移给其他单元格,而且内容也不会引起任何的溢出。

auto

最后介绍 auto 值。 minmax() 函数的最小值和最大值使用 auto ,将会有不同的含义,其含义也取决于 minmax() 函数的最小值和最大值。

如果用于最大值,那么 auto 值相当于 max-content 值;如果用于最小值,那么 auto 值相当于 min-content 。最大的最小尺寸不同于 min-content ,它通过 min-widthmin-height 来指定。

为了说明这一点,下面的的示例中,黄色的网格单元格使用 minmax() 函数,并且最小值和最大值都设置 auto

.grid {
    display: grid;
    grid-template-columns: minmax(auto, auto) 1fr 1fr;
}

minmax()函数如何工作

使用 minmax() 函数:不使用媒体查询实现响应式布局

正如我们所见,有几种情况下使用 minmax() 函数是最合适的。但也许最流行或有用的是在不使用任何媒体查询创建响应式网页设计。

来看一个网格示例:

minmax()函数如何工作

网格中的每个列的最小宽度为 200px 。根据浏览器视窗大小,网格数量会根据共最合理的宽度进行变化。这里使用了CSS的 minmax() 函数。只需要使用两行CSS代码就可以实现:

.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

除了使用 minmax() 函数之外,还有两个关键部分:

  • repeat() :这个函数允许我们给网格多个列指定相同的值。它也接受两个值:重复的次娄和重复的值
  • auto-fit :给 repeat() 函数使用这个关键词,来替代重复次数。这可以根据每列的宽度灵活的改变网格的列数

首先,在我看来这很重要,它只会让每一列的宽度相等。我们必须在 repeat() 函数中使用 auto-fit ,因为它可以灵活的控制网格的列数。尽管如此,在正确的使用的情况下是非常有用的技术。

扩展阅读

本文根据 @Ire Aderinokun 的《 How the minmax() Function Works 》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处: https://bitsofco.de/how-the-minmax-function-works/

minmax()函数如何工作

大漠

常用昵称“大漠”,W3CPlus创始人,目前就职于手淘。对HTML5、CSS3和Sass等前端脚本语言有非常深入的认识和丰富的实践经验,尤其专注对CSS3的研究,是国内最早研究和使用CSS3技术的一批人。CSS3、Sass和Drupal中国布道者。2014年出版《 图解CSS3:核心技术与案例实战 》。


以上所述就是小编给大家介绍的《minmax()函数如何工作》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web导航设计

Web导航设计

James Kalbach / 李曦琳 / 电子工业出版社 / 2009 年3月 / 69.80元

业务目标的实现,依赖于用户能够找到并使用您提供的服务。本书为您讲述创建有效导航系统的基本设计原则、开发技巧和实用建议,并附有大量的真实案例。本书研究深入,援引广泛,是极佳的参考资料和教学指南,适用于初级和中级网页设计师、产品经理和其他非设计职位,以及寻求全新视角的Web开发老手。一起来看看 《Web导航设计》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具