Como imprimir o conteúdo HTML no clique de um botão, mas não a página? [duplicado]

Esta pergunta já tem uma resposta:

quero imprimir algum conteúdo HTML, quando o Utilizador carregar num botão. Uma vez que o usuário clica nesse botão, a janela de impressão do navegador vai abrir, mas não vai imprimir a página web. Em vez disso, irá imprimir o outro Conteúdo HTML que não é mostrado na página.

Ao fazer esta pergunta, há poucas soluções que me vêm à cabeça. Mas não tenho a certeza se essas são boas ideias ou se é possível fazer algo melhor. Uma dessas soluções é:: Eu posso manter este conteúdo HTML em um div e torná-lo {[[0]} para imprimir, mas display: none Para tela. Todos os outros elementos na página web podem ser feitos em display: none para impressão e {[[0]} para o ecrã. E depois liga para imprimir.

Alguma ideia melhor?

Author: Debiprasad, 2013-06-03

6 answers

Encontrei outra solução elegante para isto:

Coloque a sua parte imprimível dentro de um div com um id como este:

<div id="printableArea">
      <h1>Print me</h1>
</div>

<input type="button" onclick="printDiv('printableArea')" value="print a div!" />
Agora vamos criar um javascript muito simples:
function printDiv(divName) {
     var printContents = document.getElementById(divName).innerHTML;
     var originalContents = document.body.innerHTML;

     document.body.innerHTML = printContents;

     window.print();

     document.body.innerHTML = originalContents;
}

Fonte: responde

 112
Author: asprin, 2017-05-23 12:10:43

Aqui está uma versão CSS pura

.example-print {
    display: none;
}
@media print {
   .example-screen {
       display: none;
    }
    .example-print {
       display: block;
    }
}
<div class="example-screen">You only see me in the browser</div>

<div class="example-print">You only see me in the print</div>
 68
Author: 2ne, 2017-09-18 09:49:42

De acordo com este link pode imprimir um div específico com

w=window.open();
w.document.write(document.getElementsByClassName('report_left_inner')[0].innerH‌​TML);
w.print();
w.close();
 48
Author: Jaay, 2017-05-23 12:10:43

Quero Ver Isto.

Exemplo http://jsfiddle.net/35vAN/

    <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>');
        /*optional stylesheet*/ //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.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>
 10
Author: Panchal Deep, 2014-07-25 12:27:10

Abaixo Do Código Pode Ajudar-Te:

<html>
<head>
<script>
function printPage(id)
{
   var html="<html>";
   html+= document.getElementById(id).innerHTML;

   html+="</html>";

   var printWin = window.open('','','left=0,top=0,width=1,height=1,toolbar=0,scrollbars=0,status  =0');
   printWin.document.write(html);
   printWin.document.close();
   printWin.focus();
   printWin.print();
   printWin.close();
}
</script>
</head>
<body>
<div id="block1">
<table border="1" >
</tr>
<th colspan="3">Block 1</th>
</tr>
<tr>
<th>1</th><th>XYZ</th><th>athock</th>
</tr>
</table>

</div>

<div id="block2">
    This is Block 2 content
</div>

<input type="button" value="Print Block 1" onclick="printPage('block1');"></input>
<input type="button" value="Print Block 2" onclick="printPage('block2');"></input>
</body>
</html>
 5
Author: Butani Vijay, 2013-06-03 10:36:58

Se você adicionar e remover o innerHTML, todo o javascript, css e mais serão carregados duas vezes, e os Eventos irão disparar duas vezes (aconteceu comigo), é melhor esconder o conteúdo, usando jQuery e css como este:

function printDiv(selector) {
    $('body .site-container').css({display:'none'});
    var content = $(selector).clone();
    $('body .site-container').before(content);
    window.print();
    $(selector).first().remove();
    $('body .site-container').css({display:''});
}

O div "site-container" contém todo o site, para que você possa chamar a função como:

printDiv('.someDiv');
 2
Author: Alejo JM, 2014-07-04 00:26:59