javascript - CSS Grid 两行嵌套在一列中

标签 javascript html css

我正在寻找一种方法,允许在一列中包含两行,而其右侧的其他两列与这两行的高度相等/灵活。查看所有三列时,宽度应为 100%(因此每列约为 33%)。这是我希望它看起来如何的示例:

https://i.imgur.com/lLPzXhS.png

我将用如下所示的可点击框填充这些框:

https://i.imgur.com/uyyDbL7.png

我尝试过使用 display: row、display: cell,但我无法为其添加任何边距,所以这是我得到的产品:

https://i.imgur.com/Ok6EgT0.png

您可以看到我设置了一些网格系统,但没有我想要的那么理想。红色框和橙色框之间没有可以设置的边距,即使我可以为绿松石色和蓝色框添加边距。

这是我的代码:

HTML:

<div class='d-table'>
    <div class='t-row'>
        <div class='t-cell one-third'>
            <div class='turqoisebox'>
                Turqoise box here
            </div>
            <div class='bluebox'>
                Blue box here
            </div>
        </div>
        <div class='t-cell one-third redbox'>
            Red box here
        </div>
        <div class='t-cell one-third orangebox'>
            Orange box here
        </div>
    </div>
</div>

CSS:

.d-table {
    display: table;
}

.t-row {
    display: table-row;
}

.t-cell {
    display: table-cell;
    margin-left: unset;
    margin-right: unset;
    /*border: 1px solid tomato;*/
}

.one-third {
    width: 30%;
}

.two-thirds {
    width: 200px;
}

.bluebox {
    background-color: #9dd8dd;
    margin: 25px;
    border-radius: 25px;
    border: solid #7dacb0;
    border-width: 3px;
    box-shadow: 2px 4px 8px 2px rgba(0,0,0,0.4);
    transition: 0.3s;
    text-align: center;
}

    .bluebox:hover {
        box-shadow: 2px 8px 16px 2px rgba(0,0,0,0.8);
    }

关于如何整齐地复制第二张图像结果有什么想法吗?

最佳答案

你可以使用flexbox。看看这个简化的例子:

.content {
    background: orange;
    margin: 1rem;
    padding: 1rem;
    flex: 1;
    color: white;
    display: flex;
}

.content > span {
    margin: auto;
}

.row {
    display: flex;
    flex-direction: row;
    background-color: blue;
    flex: 1
}

.col {
    display: flex;
    flex-direction: column;
    flex: 1;
    background-color: red;
}
<div class="row">
    <div class="col">
        <div class="row">
            <div class="content">
                <span>This is centered</span>
            </div>
        </div>
        <div class="row">
            <div class="content">
                <span>This is centered</span>
            </div>
        </div>
    </div>

    <div class="col">
        <div class="content">
            <span>This is centered</span>
        </div>
        <div class="content">
            This is not
        </div>
        <div class="content">
            This is not
        </div>
    </div>

    <div class="col">
        <div class="content">
            This is not
        </div>
        <div class="content">
            This is not
        </div>
        <div class="content">
            This is not
        </div>
        <div class="content">
            <span>This is centered</span>
        </div>
    </div>
</div>

您还可以使用最小的基于 flexbox 的网格库,例如 Flexbox Grid .

关于javascript - CSS Grid 两行嵌套在一列中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56051631/

相关文章:

javascript - 如何将 JavaScript 变量作为参数传递给 JSF 操作方法?

javascript - 淡出前置 div

html - 如何设置 Owl Carousel 导航按钮的样式(上一个或下一个)

javascript - 使用 html 中的单个按钮上传图像

html - 如何将多个图像与标题对齐?

javascript - 获取 Google Places Nearby Search 的 JSON

javascript - 许多 Sprite 类的 EaselJs 性能问题

html - 让 Angular2 路由在 IIS 7.5 上工作

html - 如何在容器中居中放置两个 float 元素?

html - 列表项中的剪辑图像