尝试连续一次显示多个 php 文件


Trying to display multiple php files at once, in a row

我目前有一个页面显示要打印的发票。 我想创建一个页面,我可以在其中输入多张发票,以便我可以打印多张发票。 当然,我可以复制代码并将其循环到新文件中,但我认为调用其他页面并将它们组装在一个页面上可能会更容易。 我看到了一些与此类似的代码,并尝试对其进行修改,但是在控制台中不断收到错误:

未捕获的语法错误:意外令牌非法

也许有一种方法只能在 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);