1

我想创建这种布局:

想要布局

我想使用流行的实用 css 框架“Tailwindcss”来实现这一点。有人知道如何进行吗?任何方向都会帮助我。

我确信这种结构是可能的,但我找不到任何东西。

此外,数据被拉出数据库并以如图所示的数字顺序到达。

非常感谢您抽出宝贵时间!

4

3 回答 3

4

自 2020 年 2 月和 Tailwind CSS v1.2 以来,完成这项任务变得非常容易:)

<div class="grid grid-cols-4 grid-rows-3">
  <div>1</div>
  <div>2</div>
  <div class="row-span-2 col-span-2">3</div>
  <div>4</div>
  <div>5</div>
  <div>6</div>
  <div>7</div>
  <div>8</div>
  <div>9</div>
</div>

酷吧?

于 2020-08-25T22:25:54.953 回答
2

您只能使用 Result 来实现该结果css grid,因为“Tailwindcss”基于 工作display: flex,因此使用它很难实现。请查看以下工作片段,希望对您有所帮助:)

.item1 { grid-area: a1; }
.item2 { grid-area: a2; }
.item3 { grid-area: a3; }
.item4 { grid-area: a4; }
.item5 { grid-area: a5; }
.item6 { grid-area: a6; }
.item7 { grid-area: a7; }
.item8 { grid-area: a8; }
.item9 { grid-area: a9; }

.grid-container {
  display: grid;
  grid-template-areas:
    'a1 a2 a3 a3'
    'a4 a5 a3 a3'
    'a6 a7 a8 a9';
}

/* Additional styling */
.grid-container > div {
  background-color: #fff;
  text-align: center;
  padding: 20px 0;
  font-size: 30px;
}
.grid-container {
  grid-gap: 1px;
  background-color: #000;
  margin: 10px;
  padding: 1px;
}
.item3 {
  display: flex;
  justify-content: center;
  align-items: center;
}
<div class="grid-container">
  <div class="item1">1</div>
  <div class="item2">2</div>
  <div class="item3">3</div>
  <div class="item4">4</div>
  <div class="item5">5</div>
  <div class="item6">6</div>
  <div class="item7">7</div>
  <div class="item8">8</div>
  <div class="item9">9</div>
</div>

于 2018-08-01T14:23:20.003 回答
0

这个网格区域插件允许您在 TailwindCSS 配置中定义网格区域并创建实用程序,然后将元素放置在网格中您想要的位置:

// tailwind.config.js
module.exports = {
  purge: {
    content: [
      './src/**/*.html',
    ],
  },
  theme: {
    extend: {
      gridTemplateAreas: {
        'default': [
          '.    .    hero hero',
          '.    .    hero hero',
          '.    .    .    .',
        ]
      },
    }
  },
  plugins: [
    require('../tailwindcss-grid-areas'),
  ],
}
<div class="lg:grid grid-areas-default grid-cols-4 w-full h-64">
    <div class="grid-in-hero">3 (Hero)</div>

    <div>1</div>
    <div>2</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>
</div>

在大于“lg”断点的屏幕上(默认 TailwindCSS 值为 1024 像素),布局将看起来像您想要的网格。

在较小的屏幕上(如果需要,您可以使用不同的断点,或者根本不使用,但在布局变得有点被您想要的 4 列压扁之前,可能有一个最小宽度),内容将仅显示在使用默认块布局规则的 DOM 顺序。假设你更大的英雄内容比其他内容更重要,你会希望这个呈现在另一个之上。

DOM 顺序也与使用屏幕阅读器等可访问技术的人相关。

于 2021-10-11T22:29:39.317 回答