我最近开始欣赏名为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>
现在,我知道该脚本有效,因为我已在其他页面上使用它并且条形码生成得很好,所以我不知道在哪里找到问题。
答案 0 :(得分:1)
检查问题是否与首先渲染图像有关的一种方法是使用setTimeout延迟PDF调用。如果这样可行,则可以考虑将其保持原样或探索其他方法,例如回调或承诺。
setTimeout(function(){
var element = document.getElementById("WHOLE_DOCUMENT");
JsBarcode(element, "Hi!");
},2000) //2000 = 2 seconds