如何在yii2中创建PDF时设置CSS?

时间:2016-04-25 05:00:01

标签: php pdf yii2

Pdf功能*  这个函数是从ajax调用后从这个函数调用它调用另一个文件在这里我显示来自数据库的数据。然后使用样式标签中的所有css部分,因为它是pdf中的样式标签prind作为文本和如果所有css文件都包含在css文件夹中,那么pdf不会以适当的格式创建

public function actionInvoicespacking(){ 
    $pdf = Yii::$app->pdf;
    $modelShipment = Shipment::find()->orderBy('ship_id DESC')->one();
    if(count($modelShipment) == 0) {

      $shipid= 1;
    } else 
    {
     $shipid= $modelShipment->ship_id;

   }
   $htmlContent = file_get_contents('http://localhost/shepherdlogistics_v1.0/backend/views/shipment/invoicespackingdata.php');
   $pdf->content = $htmlContent;
   return $pdf->render();

 }

invoicespackingdata.php

<!DOCTYPE html>
<html lang="en">

<head>
    <title>Invoice</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="css/bootstrap.fontawesome.min.css">
    <link rel="stylesheet" href="css/stylepdf.css">
    <script src="js/jquery.min.js"></script>
    <script src="js/bootstrap.min.js"></script>
    <style type="text/css">
    body {
        font-size: 18px;
        font-family: cambria;
    }

    .nopadd {
        padding: 0px;
    }
    </style>
</head>

<body>
    <div class="container">
        <br>
        <br>
        <div class="">
            <div class="col-lg-2 nopadd">
                <img src="logopdf.png" alt="logo" width="100%">
            </div>
            <div class="col-lg-10">
                <h1 style="font-size: 55px;font-weight: bold; padding: 23px 0px;">
                SHEPHERD LOGISTICS CO. W.L.L.</h1>
            </div>
        </div>
</div>
</div>

1 个答案:

答案 0 :(得分:0)

正如demo所述:

  

将跳过任何<style>标记(您必须使用cssInline属性)

如果你只有几个样式要添加到pdf中,你可以这样传递:

$pdf->content = $htmlContent;
$pdf->cssInline = '.class1 {color: red} .class2 {color:blue}';

但是如果你有很多样式,你也可以考虑使用正确的css将默认的cssFile更改为你想要的任何文件。 (默认情况下,此属性为@vendor/kartik-v/yii2-mpdf/assets/bootstrap.min.css