簡體   English   中英

jQuery將Div內容從當前頁面加載到另一個頁面

[英]jQuery Load Div Content from Current Page to Another Page

我看過一些從當前頁面外部將HTML內容加載到頁面的示例,例如

$("#divData").load("article.html #target");

現在,我需要做一些完全相反的事情! 我的意思是我需要將當前活動頁面的一部分導出到服務器上現有的.php頁面。 例如,如果我有一個類似HTML

<!DOCTYPE HTML>
<html>
<body>
  <div class="well"> 
   <div class="btn-group">
    <button class="btn">Left</button>
    <button class="btn">Middle</button>
    <button class="btn">Right</button>
   </div>
   <button id="loader" class="btn btn-default">Load To PHP Page</button>
  </div>
</body>
</html> 

我怎樣才能將well內容及其整個元素導出/加載到.PHP可以說print.php頁面,如下所示:

<?php

    require_once("dompdf_config.inc.php");

    $codigo= '<html>
                <body>
                </body>
              </html>';

    $codigo = utf8_decode($codigo);
    $dompdf = new DOMPDF();
    $dompdf->load_html($codigo);
    ini_set("memory_limit","32M");
    $dompdf->render();
    $dompdf->stream("ejemplo.pdf");

更新:

Data returned from PHP: %PDF-1.3
1 0 obj
<< /Type /Catalog
/Outlines 2 0 R
/Pages 3 0 R >>
endobj
2 0 obj
<< /Type /Outlines /Count 0 >>
endobj
3 0 obj
<< /Type /Pages
/Kids [6 0 R
]
/Count 1
/Resources <<
/ProcSet 4 0 R
/Font << 
/F1 8 0 R
>>
>>
/MediaBox [0.000 0.000 612.000 792.000]
 >>
endobj
4 0 obj
[/PDF /Text ]
endobj
5 0 obj
<<
/Creator (DOMPDF)
/CreationDate (D:20140425170443+00'00')
/ModDate (D:20140425170443+00'00')
>>
endobj
6 0 obj
<< /Type /Page
/Parent 3 0 R
/Contents 7 0 R
>>
endobj
7 0 obj
<<
/Length 71 >>
stream

0.000 0.000 0.000 rg
BT 34.016 746.579 Td /F1 12.0 Tf  [(salam)] TJ ET
endstream
endobj
8 0 obj
<< /Type /Font
/Subtype /Type1
/Name /F1
/BaseFont /Times-Roman
/Encoding /WinAnsiEncoding
>>
endobj
xref
0 9
0000000000 65535 f 
0000000008 00000 n 
0000000073 00000 n 
0000000119 00000 n 
0000000273 00000 n 
0000000302 00000 n 
0000000416 00000 n 
0000000479 00000 n 
0000000600 00000 n 
trailer
<<
/Size 9
/Root 1 0 R
/Info 5 0 R
>>
startxref
710
%%EOF

如果您想要活動頁面的整個狀態,則只需提交一個表單,該表單的輸入將包含所需的HTML。 如果您要這樣做,也可以在AJAX中執行相同的操作。

例如

HTML

<form action="your_page.php" method="post">
    <input type="hidden" name="htmlContent">
    <button type="submit">Submit HTML</button>
</form>

JS

$('form').submit(function (e) {
    $(this).children('[name=htmlContent]').val($('.well').html());
});

有兩個選擇,首先回答您的問題,您可以將div.well的內容與ajax發送到print.php

$.ajax({
    url: 'print.php',
    type: 'POST',
    data: {
        yourData: $('div.well').html()
    },
    success: function(msg) {
        alert('Data returned from PHP: ' + msg);
        // now do something with your returned data, liked load it in a new window.
    },
    error: function (xhr, ajaxOptions, thrownError) {
        alert('AJAX request failed! ' + xhr.status + ' ' + thrownError);
    }
});

然后,您可以echo $_POST['yourData']; 在您的print.php頁面上使用print.php面上的div.well

或者,如果加載的內容是靜態的,則可以將.load("page.html div.well")放在print.php頁面上(請參見下面的注釋)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM