在Web开发中,我们经常需要创建网格布局,其中网格单元的数量可能不固定,但整个网格区域却必须限制在一个固定大小的容器内。例如,一个画板应用可能需要生成一个10x10或100x100的网格,但无论网格大小如何,其总宽度和高度都应保持不变,每个单元格则根据总数自适应调整大小。这种需求带来了挑战:如何精确计算每个单元格的尺寸,使其既能填充整个容器,又不会超出边界。
传统的CSS布局方法(如百分比宽度或Flexbox/Grid的自动伸缩)在某些场景下可能难以提供像素级的精确控制,尤其当需要严格的方形单元格且总数变化时。本教程将介绍一种结合JavaScript动态计算和CSS布局的解决方案,以实现这种精确且自适应的网格布局。
解决此问题的核心在于利用JavaScript来动态计算每个网格单元格(square)的实际宽度和高度。基本步骤如下:
首先,我们需要一个固定的父容器来承载整个网格,以及一个JavaScript入口文件。
动态自适应网格
grid-container 是我们的固定尺寸容器,它将在JavaScript中被填充。
CSS主要负责定义grid-container的固定尺寸、中心定位以及grid-row