- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试使用 css 网格布局模块来显示 12 列 - 3 行网格。
我需要让第一行仅显示 2 个元素(第一个在网格的左侧,第二个在右侧)。我使用 10 个句点将它们与空单元格分开。
然后我需要以下行来自动显示剩余的元素。
我决定使用 grid-template-areas
来更好地控制定位,但这可能不是最好的方法,因为我似乎必须给出一个特定的 grid-area
所有元素的名称。
此外,当我尝试对剩余的单元格使用 auto grid-area
属性以便它们可以自动填充第 3 行时,它们似乎填充了空单元格从第一行开始。
解决这个问题最有效的方法是什么?
这是我的代码:
.grid {
display: grid;
grid-template-areas:
"elem1 . . . . . . . . . . elem2"
"elem3 elem4 elem5 elem6 elem7 elem8 elem9 elem10 elem11 elem12 elem13 elem14";
}
.elem{
text-align: center;
color: white;
}
.elem1 {
background-color: blue;
grid-area: elem1;
}
.elem2 {
background-color: red;
grid-area: elem2;
}
.elem3 {
background-color: cyan;
grid-area: elem3;
}
.elem4 {
background-color: green;
grid-area: elem4;
}
.elem5 {
background-color: magenta;
grid-area: elem5;
}
.elem6 {
background-color: blue;
grid-area: elem6;
}
.elem7 {
background-color: red;
grid-area: elem7;
}
.elem8 {
background-color: cyan;
grid-area: elem8;
}
.elem9 {
background-color: green;
grid-area: elem9;
}
.elem10 {
background-color: magenta;
grid-area: elem10;
}
.elem11 {
background-color: blue;
grid-area: elem11
}
.elem12 {
background-color: red;
grid-area: elem12;
}
.elem13 {
background-color: cyan;
grid-area: elem13;
}
.elem14 {
background-color: green;
grid-area: elem14;
}
.elem15 {
background-color: magenta;
grid-area: auto;
}
.elem16 {
background-color: green;
grid-area: auto;
}
.elem17 {
background-color: magenta;
grid-area: auto;
}
.elem18 {
background-color: cyan;
grid-area: auto;
}
.elem19 {
background-color: magenta;
grid-area: auto;
}
.elem20 {
background-color: blue;
grid-area: auto;
}
<div class="grid">
<div class="elem elem1">
elem1
</div>
<div class="elem elem2">
elem2
</div>
<div class="elem elem3">
elem3
</div>
<div class="elem elem4">
elem4
</div>
<div class="elem elem5">
elem5
</div>
<div class="elem elem6">
elem6
</div>
<div class="elem elem7">
elem7
</div>
<div class="elem elem8">
elem8
</div>
<div class="elem elem9">
elem9
</div>
<div class="elem elem10">
elem10
</div>
<div class="elem elem11">
elem11
</div>
<div class="elem elem12">
elem12
</div>
<div class="elem elem13">
elem13
</div>
<div class="elem elem14">
elem14
</div>
<div class="elem elem15">
elem15
</div>
<div class="elem elem16">
elem16
</div>
<div class="elem elem17">
elem17
</div>
<div class="elem elem18">
elem18
</div>
<div class="elem elem19">
elem19
</div>
<div class="elem elem20">
elem20
</div>
</div>
非常感谢
最佳答案
使用带有隐式网格的 grid-template-areas
属性,grid auto placement algorithm将在创建新行之前查找未占用的单元格以进行填充(有关更多详细信息,请参见底部)。
只需指定您想要的:
.elem:nth-last-child(-n + 6) {
grid-row-start: 3;
}
此规则会覆盖默认的自动放置过程,将最后六个元素放在第三行。
.grid {
display: grid;
grid-template-areas:
"elem1 . . . . . . . . . . elem2"
"elem3 elem4 elem5 elem6 elem7 elem8 elem9 elem10 elem11 elem12 elem13 elem14";
}
/* NEW */
.elem:nth-last-child(-n + 6) {
grid-row-start: 3;
}
.elem{
text-align: center;
color: white;
}
.elem1 {
background-color: blue;
grid-area: elem1;
}
.elem2 {
background-color: red;
grid-area: elem2;
}
.elem3 {
background-color: cyan;
grid-area: elem3;
}
.elem4 {
background-color: green;
grid-area: elem4;
}
.elem5 {
background-color: magenta;
grid-area: elem5;
}
.elem6 {
background-color: blue;
grid-area: elem6;
}
.elem7 {
background-color: red;
grid-area: elem7;
}
.elem8 {
background-color: cyan;
grid-area: elem8;
}
.elem9 {
background-color: green;
grid-area: elem9;
}
.elem10 {
background-color: magenta;
grid-area: elem10;
}
.elem11 {
background-color: blue;
grid-area: elem11
}
.elem12 {
background-color: red;
grid-area: elem12;
}
.elem13 {
background-color: cyan;
grid-area: elem13;
}
.elem14 {
background-color: green;
grid-area: elem14;
}
.elem15 {
background-color: magenta;
grid-area: auto;
}
.elem16 {
background-color: green;
grid-area: auto;
}
.elem17 {
background-color: magenta;
grid-area: auto;
}
.elem18 {
background-color: cyan;
grid-area: auto;
}
.elem19 {
background-color: magenta;
grid-area: auto;
}
.elem20 {
background-color: blue;
grid-area: auto;
}
<div class="grid">
<div class="elem elem1">elem1</div>
<div class="elem elem2">elem2</div>
<div class="elem elem3">elem3</div>
<div class="elem elem4">elem4</div>
<div class="elem elem5">elem5</div>
<div class="elem elem6">elem6</div>
<div class="elem elem7">elem7</div>
<div class="elem elem8">elem8</div>
<div class="elem elem9">elem9</div>
<div class="elem elem10">elem10</div>
<div class="elem elem11">elem11</div>
<div class="elem elem12">elem12</div>
<div class="elem elem13">elem13</div>
<div class="elem elem14">elem14</div>
<div class="elem elem15">elem15</div>
<div class="elem elem16">elem16</div>
<div class="elem elem17">elem17</div>
<div class="elem elem18">elem18</div>
<div class="elem elem19">elem19</div>
<div class="elem elem20">elem20</div>
</div>
Grid Item Placement Algorithm 中有五个主要步骤(0-4).
第一步是定位未自动定位的网格元素。这会优先考虑您指定位置的元素。
过程中的最后是定位剩余的网格项,它是这样说的:
The auto-placement cursor defines the current "insertion point" in the grid, specified as a pair of row and column grid lines. Initially the auto-placement cursor is set to the start-most row and column lines in the implicit grid.
本节还解释了为什么您的自动放置元素从第 1 行第 2 列开始:
If the item has an automatic grid position in both axes:
Increment the column position of the auto-placement cursor until either this item’s grid area does not overlap any occupied grid cells, or the cursor’s column position, plus the item’s column span, overflow the number of columns in the implicit grid, as determined earlier in this algorithm.
关于html - CSS GRID - 具有空单元格和自动放置的网格模板区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47638009/
语句 1: [2,4,6,7,8].each do |i| (i % 2 == 0) || (puts "Not even" && break) puts i end 声明 2: [2
我有一张正在显示的卡片,上面有一些信息。我想将其包装在SingleChildScrollView中,因为我还有更多项目要添加到卡中,但是当我这样做时,屏幕只是空白吗?我曾尝试将其作为根(脚手架主体)放
我有一个带有窗体的 View ,该窗体显示ViewModel中ObservableCollection中对象的数据。 ObservableCollection使我可以浏览数据。 ObservableC
如何将时间戳附加文件名放在HDFS中? hadoop fs -put topic_2018-12-15%2016:31:15.csv /user/file_structure/ 最佳答案 您只是在运行
我正在寻求一些帮助,以找出为什么以下叠加函数的运行时间会随着每次连续运行而增加。 据我所知,如果缓冲区中的文本保持不变,则运行时间应该是相同的——即,仅向左/向右移动光标应该不会增加运行时间(但它确实
我有一个事件指示器,它显示在中间。如何将其放置在 View 的左上角? var activityIndicator = UIActivityIndicatorView() func show() {
首先,我想提前感谢所有回答这个问题的人。非常感谢您的帮助。这是我第一次在这里发帖,所以如果我发帖不礼貌,请原谅我。 我的问题是关于方法原型(prototype)的: void copySubtree(
我正在开发一个应该是通用的应用程序,一个适用于 iPad 和 iPhone 的应用程序。我想让他们的界面尽可能相似。在 iPhone 应用程序中,我使用的是选项卡栏 Controller ,其中一个选
我目前正在使用 JS 开发 REST API,但遇到以下问题:该代码有效,但如果我尝试删除、放置或修补不存在的条目,它不会返回错误,但会打印成功消息。这是为什么?获取路由完美运行。 app.route
.a{ width:500px; height:500px; background:yellow; border: 3px dashed black; }
首先,请引用下图: 这基本上是我对布局的想法。 我想要的是: 内容 div 成为“主要焦点”,例如当浏览器 调整大小,它应该留在中间; 当浏览器被调整大小时,我希望这两个图像基本上 位于内容 div
我的应用程序需要使用内存映射并发访问数据文件。我的目标是使其在共享内存系统中可扩展。研究了内存映射文件库实现的源码,想不通: 在多个线程中从 MappedByteBuffer 中读取是否合法? get
我有一个 JDesktopPane 并希望以网格样式显示 JInternalFrames 而无需覆盖框架。框架的尺寸会有所不同,因此应动态分配它们的位置。我可以存储最后放置的框架的坐标,但可以移动、最
根据https://isocpp.org/wiki/faq/dtors#placement-new传递给placement-new的地址必须正确对齐。但它给出的例子似乎与此相矛盾。 char memo
我最近一直在查看 Illumos 源代码,发现了一些奇怪的东西。 在他们的源代码中,函数类型是这样写的: static int outdec64(unsigned char *out, unsigne
您好,我目前正在尝试在我的一张图片旁边放置一个图例,但我在放置时遇到了问题。 我想将图例放在图像的左侧或右侧。这是我当前的代码: .my-legend .legend-title { text-a
根据文档, print 之间的唯一区别和 say 似乎是后者添加了 "\n"(并使用 .gist 进行字符串化)。然而, perl6 -e 'print "del\b\b"' 打印“d”,有效地应用转
所以我试图将我的图像标志放在背景上,但我的背景突然被裁剪,出现了一半的黑屏。如图: 我的 main.dart 代码: import 'package:flutter/material.dart'; i
我正在使用 Azure DevOps 构建 python 轮。我想让它尽可能通用,以便团队中的每个人都可以使用相同的管道来构建自己的 python 轮并将它们部署在一些 databricks 工作区中
在构建标准(非 WordPress)网页时,我通常会在正文末尾之前加载所有 javascript 文件,然后包含页面特定 js 代码的部分。 WorPress 建议使用 wp_enqueue_scri
我是一名优秀的程序员,十分优秀!