如何在@page中垂直居中div并打印(DomPDF和Laravel)

hpcdzsge  于 2023-10-22  发布在  其他
关注(0)|答案(3)|浏览(142)

您好!我目前正在使用Laravel 8的DomPDF库来使用原生CSS生成可打印的PDF(因为Bootstrap和其他导入无法很好地与此库一起工作)。
我发现很难格式化某些部分,以适应一个页面的死点。我找不到任何关于在可打印格式(如DomPDF)中垂直居中的资源。
边距只处理左侧和右侧,而顶部和底部没有任何影响。
我的CSS示例

@page
{
    margin-right: 1.5cm;
    margin-left: 1.5cm;
    size:8.5in 11in;
}

.page
{
    position: relative;
    display: flex;
}

.page-break
{
    page-break-after: always;
}

.intro-title-block
{
    margin: auto;
    text-align: center;
}

DomPDF Sample Sniphon

w80xi6nr

w80xi6nr1#

您可以使用display: tabledisplay: table-cell

<div class="container">
  <div class="content">
    <!-- Your content here -->
  </div>
</div>
.container {
  display: table;
  width: 100%;
  height: 100%;
}

.content {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}
h43kikqp

h43kikqp2#

DomPDF不支持Flexbox,我使用以下代码解决了它:

.page{
  position: absolute;
  transform: translateY(-50%);
}
mkshixfv

mkshixfv3#

你可以用Flex显示器来设计页面的样式。

.page{
  display:flex;
  align-items:center;
}

相关问题