dompdf HTML到PDF - 无法设置页面边距

问题描述 投票:17回答:2

版本:0.6.0 beta 3

我试着以各种方式让dompdf设置页面的边距。我有一个很长的页面,有很多文字,分为章节......

我的css是这样的:

#wrapper{
    padding:8px;
}

/* other styles... */

@page{margin: 0.2in 0.5in 0.2in 0.5in;}

当PHP是

<?php
ob_start(); // begin collecting output
include 'makemypdf.php'; // this page output the html
$html = ob_get_clean(); // retrieve output from makemypdf.php and stop buffering


require_once("dompdf/dompdf_config.inc.php");

$dompdf = new DOMPDF();
$dompdf->load_html($html);
$dompdf->render();
$dompdf->stream("sample.pdf", array("Attachment" => false));

?>

但我得到的是一个没有边距的页面!只应用#wrapper的填充...并且它们仅应用于整个PDF的开头和结尾...

我做错了什么?

PS - 似乎只应用了底部保证金......但我不确定......

PPS - 我试过这个css:body {margin-top:40px; } html {margin-top:40px; } @page {margin-top:40px; }

php html css margin dompdf
2个回答
40
投票

我发现在这个版本的dompdf中,body或@page都不起作用。

问题出在主要的CSS中,我把这个行放在每一个:

*{margin:0;padding:0}

我发现PDF的边距是根据HTML的边距决定的,所以我用全局选择器删除了该行并替换为:

th,td,p,div,b ... {margin:0;padding:0}
html{margin:40px 50px}

这是“不期望的”,我在每一页都得到了正确的余量。

现在我很开心。我真的不知道是谁投票我的问题,我认为这非常重要!事实上,互联网上的每个地方都有错误的答案(使用正文或@page边距)。

解决方案:在CSS html {margin:...}中使用


0
投票

这解决了我的问题:

        @page {
            margin: 0px 0px 0px 0px !important;
            padding: 0px 0px 0px 0px !important;
        }
© www.soinside.com 2019 - 2024. All rights reserved.