我已经看到了一些将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
答案 0 :(得分:1)
如果您想要活动页面的整个状态,您只需提交一个包含所需HTML的输入的表单即可。如果这是你想要的,你也可以在AJAX中做同样的事情。
E.g。
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());
});
答案 1 :(得分:0)
有两个选项,首先回答您的问题,您可以将带有ajax的div.well
内容发送到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
使用该页面上的div.well
。
如果加载的内容是静态的,您可以将.load("page.html div.well")
放在print.php
页面上(请参阅下面的评论)。