我有一个元素列表,我希望用户能够只打印点击的元素,而不是整个周围的页面。元素看起来如下:使用Javascript动态生成HTML页面
<div class="element" id="#element1">Element 1</div>
<div class="element" id="#element2">Element 2</div>
<div class="element" id="#element3">Element 3</div>
为了能够只打印该元素的用户点击,我使用此代码来获取点击的任何元素:
jQuery(document).ready(function($) {
$('.element').click(function() {
var clickedEl = $(this).attr('id');
printDiv(clickedEl);
return false;
});
});
的点击的元素的ID然后传递给一个函数,用于打印创建一个非常简单的HTML页:
function printDiv(id) {
var printContents = document.getElementById(id).innerHTML;
var printContentsBefore = '<html><head>\
<link rel="stylesheet" href="/css/blabla_print.css" type="text/css" />\
</head><body><table><tr>';
var printContentsAfter = '</tr></table></body></html>';
var originalContents = document.body.innerHTML;
document.body.innerHTML = printContentsBefore + printContents + printContentsAfter;
//document.body.innerHTML = printContents;
window.print();
document.body.innerHTML = originalContents;
}
代码排序的作品,但我有两个问题:
- 弹出的打印窗口包含大约一半时间点击元素的数据。窗户的另一半是空的。这怎么可能,我该如何解决它?
- 在生成的页面中,我试图加载一个CSS文件来格式化内容的外观,但没有任何运气。我想尽可能在这里做什么,如果是的话,怎么样?
并且万一它是相关的;该代码正在基于WordPress的页面上使用。
谢谢!
谢谢您的回答和一般反馈。我尝试删除重置为原始内容,但问题仍然存在。尽管如此,我认为这是我的一个解决方案。看起来window.print()在很多时候很早就开始了。你是否对我的第二个问题有评论? – danjah