10

HTMLページをpdfファイルに変換するためにDOMPDF(v 0.5.2)を使用しています。

PHP スクリプトの実行後 (予想どおり)、pdf ファイルが表示されますが、どのコンテンツにもスタイルが適用されません。私が知る限り、float プロパティは DOMPDF では機能しないため、これを回避するためにいくつかの作業を行う必要がありますが、フォント スタイルも適用されていません。

スタイルを含める 3 つの方法すべてを試しました。スタイル シートの添付、

<link href="styles.css" rel="stylesheet" type="text/css">

ヘッダーの書き方、

<style>...</style>

およびインライン スタイル。

<div class="..." style="...">

PDFを作成するためのphpファイルはこんな感じ...

<?php 
ob_start(); 
?>
<html>
<head>

<link href="flhaha.css" rel="stylesheet" type="text/css">

</head>

<body>
... content (divs, etc) 
</body>
</html>
<?php 
require_once("../../scripts/dompdf/dompdf_config.inc.php"); 
$dompdf = new DOMPDF(); 
$dompdf->load_html(ob_get_clean()); 
$dompdf->render(); 
$dompdf->stream('test.pdf');
?>

正常に読み込まれ、pdf を開いたときに適切に表示されるコンテンツ内の画像がありますが、まだスタイルはありません。

前もって感謝します!

編集 #1: 上記のタグは、「スタイル」ではなく「スタイル」であることを意図していました。タイプミスを修正しました。

4

3 に答える 3

4

<style>要素ではなく要素の間にスタイルを含めることで、内部スタイルシートを作成できます<styles>

以下の stmt は間違っています:

<styles>...</styles>

そのはず :

<style> ... </style>

インライン スタイルは、次のように指定する必要があります。

<div class="className" style="color:red;text-align: left;">

以下に示すように、外部スタイルシートを含める必要があります。

<link rel="stylesheet" type="text/css" media="screen" href="styles.css" />

外部スタイル シートが機能しない場合は、ソース ファイルのパスを確認してください。

于 2013-08-02T04:15:06.310 に答える
1

簡単な解決策は、CSSを別の(.php)または他のサーバースクリプトファイルに入れて、pdfファイルに含めることです。例えば。あなたはpdf用のpdf.blade.phpファイルを持っています

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="description" content="">
    <meta name="author" content="">
    {{-- <link rel="icon" href="/favicon.ico"> --}}

    <title>Starter Template for Bootstrap</title>
<style type="text/css">
@include('pdf.style')
</style>
  </head>
  <body>

    <nav class="navbar navbar-inverse navbar-fixed-top">
      <div class="container">
        <div class="navbar-header">
          <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
            <span class="sr-only">Toggle navigation</span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
          </button>
          <a class="navbar-brand" href="#">Project name</a>
        </div>
        <div id="navbar" class="collapse navbar-collapse">
          <ul class="nav navbar-nav">
            <li class="active"><a href="#">Home</a></li>
            <li><a href="#about">About</a></li>
            <li><a href="#contact">Contact</a></li>
          </ul>
        </div><!--/.nav-collapse -->
      </div>
    </nav>

    <div class="container">

      <div class="starter-template">
        <h1>Bootstrap starter template</h1>
        <p class="lead">Use this document as a way to quickly start any new project.<br> All you get is this text and a mostly barebones HTML document.</p>
      </div>

    </div><!-- /.container -->
  </body>
</html>

css ファイル style.css があるとします。次のステップは、css ファイルの内容をコピーして、新しい style.blade.php に貼り付けることです。

今それをあなたのpdfファイルに含めてください。

<style>
  @include('style')
</style>    

それは私にとっては簡単なトリックでした。

于 2016-09-16T08:30:16.530 に答える