我目前有一个页面显示要打印的发票。 我想创建一个页面,我可以在其中输入多张发票,以便我可以打印多张发票。 当然,我可以复制代码并将其循环到新文件中,但我认为调用其他页面并将它们组装在一个页面上可能会更容易。 我看到了一些与此类似的代码,并尝试对其进行修改,但是在控制台中不断收到错误:
未捕获的语法错误:意外令牌非法
也许有一种方法只能在 php 中做到这一点?
我将一系列发票发布到此php文件:
<?php
$invoiceList = $_POST["invoiceRequest"];
$invoices = explode("'n", $invoiceList);
echo '<html>';
echo '</head>';
echo '<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>';
echo '<script type="text/javascript">';
echo '$(document).ready(function(){';
foreach($invoices as $page) {
echo "$.get('ajax/invoices/invoicePrint.php?invoiceId=".$page."').success(function(html) {
$('#page".$page."').html(html);
});";
}
echo '});';
echo '</script>';
echo '</head>';
echo '<body>';
foreach($invoices as $page) {
echo '<div id = "page'.$page.'"></div>';
}
echo '</body>';
echo '</html>';
?>
exploding
按'n
发布数据可能会在数组值中留下一些不需要的字符(如 'r
,这也将被解释为换行并导致Unexpected token ILLEGAL
错误)。为了回答这个特定问题,我建议您trim()
价值观。
您还可以通过使其更短、更清晰来改进您的实际代码。
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$(".invoice").each(function(){
$(this).load("ajax/invoices/invoicePrint.php?invoiceId="+$(this).data('invoiceid'));
});
});
</script>
</head>
<body>
<?php foreach(explode("'n", $_POST["invoiceRequest"]) as $page): ?>
<div data-invoiceid="<?php echo trim($page); ?>" class="invoice"></div>
<?php endforeach; ?>
</body>
</html>
您可以使用 cURL 而不是 ajax 来获取文档http://php.net/manual/en/book.curl.php
另一种选择是简单地使用file_get内容
http://php.net/manual/en/function.file-get-contents.php
echo file_get_contents('ajax/invoices/invoicePrint.php?invoiceId='.$page);