网格项设为 relative 时仍属网格流,可微调位置;2. 设为 absolute 则脱离网格流,需父容器有定位上下文(如 relative)以正确参照;3. 绝对定位元素不参与自动布局,可能影响结构,建议用于覆盖元素;4. 优先使用 Grid 布局,定位仅作补充。
在 Grid 布局中使用 CSS 定位(如 position: absolute 或 position: relative)时,需要理解网格容器和子元素之间的关系以及定位如何与网格轨道交互。
当一个网格项(grid item)设置为 position: relative 时,它仍然遵循 Grid 布局的排列规则。你可以通过 top、bottom、left、right 在其原本占据的网格区域内进行微调。
说明:如果将网格项设为 position: absolute,它会脱离正常的网格布局流。此时它的定位参考点取决于最近的已定位祖先元素(即 position 不是 static 的元素)。
关键点:假设你想让某个网格项从其单元格右上角突出显示:
.grid-container {
display: grid;
grid-template-columns: 1fr 1fr;
position: relative; /* 创建定位上下文 */
}
.grid-item {
position: absolute;
top: 10px;
right: 10px;
width: 50px;
height: 50px;
}
在 Grid 中混合使用定位需注意以下几点:

基本上就这些。Grid 本身已经提供了强大的布局能力,只有在需要精确层叠或偏移时才建议使用定位辅助。