Как “отдать на печать” конкретный div?


Реализация состоит из трёх этапов:

- Подготовка html конкретного div-а;
- Создание модального окна для печати;
- Передача html в модальное окно.

<html>
<head>
<script type="text/javascript" src="http://jqueryjs.googlecode.com/files/jquery-1.3.1.min.js" > </script>
<script type="text/javascript">
function PrintElem(elem) {
Popup($(elem).html());
}

function Popup(data) {
var mywindow = window.open('', 'my div', 'height=400,width=600');
mywindow.document.write('<html><head><title>my div</title>');
mywindow.document.write('<link rel="stylesheet" href="main.css" type="text/css" />');
mywindow.document.write('</head><body >');
mywindow.document.write(data);
mywindow.document.write('</body></html>');
mywindow.document.close();
mywindow.focus();
mywindow.print();
mywindow.close();
return true;
}
</script>
</head>
<body>
<div id="mydiv"> This will be printed. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque a quam at nibh adipiscing interdum. Nulla vitae accumsan ante. </div>
<div>This will not be printed. </div>
<div id="anotherdiv">Nor will this. </div>
<input type="button" value="Print Div" onclick="PrintElem('#mydiv')" />
</body>
</html>