常见的九宫格布局可以使用flex布局实现,但是flex布局有个致命的缺陷,比如3行3列的布局,当第不足3个元素的时候,元素依然是平局平铺的,这样就不满足九宫格的效果,这种情况,使用grid布局可以轻松搞定这个问题
html布局
<div class="layout"><div class="item">1</div><div class="item">2</div><div class="item">3</div><div class="item">3</div><div class="item">5</div><div class="item">6</div><div class="item">7</div><div class="item">8</div>
</div>
css样式
<style>.layout{display: grid;/*fr是山哥单位,如果想一行展示4个元素,那么填上4个fr即可*/grid-template-columns: 1fr 1fr 1fr;gap: 10px;margin-left: 10%;width: 80%;height: 80vh;}.item{background: chartreuse;display: flex;/*控制元素上下居中*/justify-content: center;/*控制元素左右居中*/align-items: center;}</style>
效果