freeCodeCamp/curriculum/challenges/chinese/01-responsive-web-design/css-grid/create-flexible-layouts-usi...

1.4 KiB
Raw Blame History

id title challengeType videoUrl forumTopicId
5a94fe5469fb03452672e461 使用 auto-fill 创建弹性布局 0 https://scrimba.com/p/pByETK/cmzdycW 301126

--description--

重复方法带有一个名为自动填充auto-fill的功能。它的功能是根据容器的大小,尽可能多地放入指定大小的行或列。你可以通过结合auto-fillminmax来更灵活地布局。

在最右侧的预览区中,grid-template-columns被设置为:

repeat(auto-fill, minmax(60px, 1fr));

上面的代码效果:列的宽度会随容器大小改变,在可以插入一个 60px 宽的列之前,当前行的所有列会一直拉伸(译者注:动手试一下你就明白了)。 注意: 如果容器无法使所有网格项放在同一行,余下的网格项将移至新的一行。

--instructions--

在第一个网格中,用auto-fillrepeat来填充网格,其中列宽的最小值为60px,最大值为1fr。你可以调整最右侧的预览区大小,查看自动填充效果。

--hints--

container类应该有grid-template-columns属性且使用repeatauto-fill,以便将最小宽度为60px,最大宽度为1fr的列填充至网格。

assert(
  code.match(
    /.container\s*?{[\s\S]*grid-template-columns\s*?:\s*?repeat\s*?\(\s*?auto-fill\s*?,\s*?minmax\s*?\(\s*?60px\s*?,\s*?1fr\s*?\)\s*?\)\s*?;[\s\S]*}/gi
  )
);

--solutions--