Laravel - 在加载Javascript后生成PDF

时间:2017-12-03 17:23:11

标签: javascript laravel pdf laravel-5

我最近开始欣赏名为http://lindell.me/JsBarcode/的条形码生成器 - 但问题是,我需要将这些条形码包含在生成的pdf中进行打印,不幸的是,无论我尝试什么那一刻,我无法在pdf中生成条形码。

目前我使用:barryvdh / laravel-dompdf来生成我的PDF,虽然它可以很好地加载图像,但我不确定它是否有可能让我的javascript执行然后继续创建pdf从那以后。

如果不可能,这里有人对我应该做什么有任何建议吗?

目前我的条码图像使用以下格式生成:

更新

这是来自我的控制器,它需要PDF:

  public function downloadPDF(Shipment $shipment){
            $shipment_details = $shipment->shipment_details;


      $pdf = PDF::loadView('shipments.pdf', compact('shipment','shipment_details'));
     return $pdf->stream('shipment'.$shipment->url_string.'.pdf');
        }

这就是使用提供的JsBarcode脚本创建图像的方法:

<head>  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <script src="/dist/JsBarcode.all.js"></script>

    <script>
        Number.prototype.zeroPadding = function(){
            var ret = "" + this.valueOf();
            return ret.length == 1 ? "0" + ret : ret;
        };
    </script>
</head>

并在主体中:

<img id="barcode3"/>
<script>JsBarcode("#barcode3", "{{$shipment->pro_number}}", {
    format:"CODE39",
    displayValue:true,
    fontSize:20
});</script>

现在,我知道该脚本有效,因为我已在其他页面上使用它并且条形码生成得很好,所以我不知道在哪里找到问题。

1 个答案:

答案 0 :(得分:1)

检查问题是否与首先渲染图像有关的一种方法是使用setTimeout延迟PDF调用。如果这样可行,则可以考虑将其保持原样或探索其他方法,例如回调或承诺。

setTimeout(function(){
  var element = document.getElementById("WHOLE_DOCUMENT");
  JsBarcode(element, "Hi!");
},2000) //2000 = 2 seconds