我有这个代码将一些数据导出到pdf中。我想从外部css文件中添加css(在使用的html中没有提到)
/*********************************** Export PDF ****************************************************/
if($request->query->get('exportPDF')!= null){
// Configure Dompdf according to your needs
$pdfOptions = new Options();
$pdfOptions->set('defaultFont', 'Arial');
// Instantiate Dompdf with our options
$dompdf = new Dompdf($pdfOptions);
// Retrieve the HTML generated in our twig file
$html = $this->renderView('dashboard/user_table.html.twig', [
'users' => $users
]);
// Load HTML to Dompdf
$dompdf->loadHtml($html);
// (Optional) Setup the paper size and orientation 'portrait' or 'portrait'
$dompdf->setPaper('A3', 'landscape');
// Render the HTML as PDF
$dompdf->render();
// Output the generated PDF to Browser (force download)
$dompdf->stream("exportUsers.pdf", [
"Attachment" => true
]);
}
user_table.html只是一个带有<table>
的文件
谁有一个来自其他模板中加载的css文件的类。这意味着对于DomPDF,包含css的文件是未知的,因此我的pdf中没有css的表。我试图直接在我的html中添加样式表,但导入不是那样的。但我不想在html中添加它,css加载是一个更高级别的模板。
如何从这个结构添加外部文件(如bootstrap等)?我不知道这是否可能。谢谢您的帮助 ;)
必须在您为DomPDF提供的HTML中引用css文件。
如果您不想更改twig模板,可以使用以下解决方法:
$dompdf = new Dompdf();
$html = $this->renderView('dashboard/user_table.html.twig', [
'users' => $users
]);
$html .= '<link type="text/css" href="/absolute/path/to/pdf.css" rel="stylesheet" />';
$dompdf->loadHtml($html);
请注意,根据HTML规范,将link
标记添加到正文是无效的。使用当前的Dompdf版本,它可以工作,但它可能在将来的版本中不起作用。
你可以随时使用像这样的Including a non-twig file from twig解决方案将外部文件内容读入模板属性,因此css将内联呈现并与mpdf兼容。