html - Bootstrap 4 - 卡片列中的响应卡片

标签 html css twitter-bootstrap bootstrap-4

我正在玩 Bootstrap 4,但在 div 中使用 class="card-columns" (此类对具有此类的 div 内的卡片应用类似 Masonry 的效果。

在 Bootstrap 3 中,很容易设置样式并使“卡片”具有响应性,因为可以应用类似 class="col-md-3 col-sm-6 col- xs-12" 到包含 thumbnailcaption 等的 div。

如何在Bootstrap 4中使用卡片达到同样的效果?

这是 HTML:

<body>

<div class="container-fluid">
    <div class="row">

        <div class="col-md-4 hidden-sm-down" id="map_container">
            <p>here we put the map</p>
        </div>

        <div class="col-md-8 col-sm-12 right_box">

            <div class="row">

                // here there's code for navbar

            </div><!-- row -->

            <div class=row">
                <div class="card-columns">
                    <?php
                    // Create and check connection
                    
                    if ($result->num_rows > 0) {

                        // output card design
                        while($row = $result->fetch_assoc()) {

                            echo '<div class="card">
                                    <img class="card-img-top" src="dance' . $row["id"] . '.jpg" alt="' . $row["name"] . '">
                                    <div class="card-block">
                                        <h4 class="card-title">' . $row["name"] . '</h4>
                                        <p class="card-text">Text. Card content.</p>
                                    </div>
                                    <div class="card-footer text-muted">
                                        <ul class="list-inline">
                                            <li><i class="fa fa-user"></i></li>
                                            <li>14</li>
                                        </ul>
                                    </div>
                                  </div><!-- card -->';
                        }
                    } else {
                        echo "0 results";
                    }

                    $conn->close();
                    ?>
                </div><!-- container card-columns -->
            </div><!-- row -->
        </div><!-- col-md-8 right_box -->
    </div><!-- row -->
</div><!-- container-fluid -->
</body>

这是我使用的 CSS:

#map_container {
background-image: url(map.png);
height: 100vh;
}

.right_box {
-webkit-box-shadow: -2px 0px 2px 0px rgba(0,0,0,0.75);
-moz-box-shadow: -2px 0px 2px 0px rgba(0,0,0,0.75);
box-shadow: -2px 0px 2px 0px rgba(0,0,0,0.75);
}

.card {
border-radius: 0 !important;
border: 0 none;
-webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
-moz-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
margin-left: 1px;
margin-right: 1px;
}

.card-img-top {
width: 100%;
border-radius: 0 !important;
}

.card-columns {
padding-top: 15px;
}

为了让我的情况更清楚,下面给出了两张图片:

Large screen

Smaller screen

我希望卡片在较小的屏幕上垂直堆叠。

感谢您的建议!

最佳答案

2019 年更新 - Bootstrap 4

您可以简单地使用 SASS mixin 来更改每个断点/网格层中的卡片数量。

.card-columns {
  @include media-breakpoint-only(xl) {
    column-count: 5;
  }
  @include media-breakpoint-only(lg) {
    column-count: 4;
  }
  @include media-breakpoint-only(md) {
    column-count: 3;
  }
  @include media-breakpoint-only(sm) {
    column-count: 2;
  }
}

SASS 演示:http://www.codeply.com/go/FPBCQ7sOjX

或者,像这样仅 CSS...

@media (min-width: 576px) {
    .card-columns {
        column-count: 2;
    }
}

@media (min-width: 768px) {
    .card-columns {
        column-count: 3;
    }
}

@media (min-width: 992px) {
    .card-columns {
        column-count: 4;
    }
}

@media (min-width: 1200px) {
    .card-columns {
        column-count: 5;
    }
}

纯 CSS 演示:https://www.codeply.com/go/FIqYTyyWWZ

关于html - Bootstrap 4 - 卡片列中的响应卡片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34140793/

相关文章:

javascript - Accordion 样式不可展开和不可点击

javascript - 如何在两个链接之间使用 toggleClass 方法

javascript - 如何用 reactjs 折叠 div?

css - 使 Bootstrap 导航栏页脚停留在页面或屏幕的底部

javascript - 加载 javascript 后加载 Mathjax

javascript - Angular 1 ng-如果不显示div

javascript - Twitter Bootstrap 弹出窗口在第一次点击时不起作用

javascript - Canvas 宽度和高度 - webview

html - 如何使用 IE8 为 HTML 表格添加透明度

javascript - 在向导表单上使用欧芹(3 个步骤)