No artigo anterior, mencionei que o Canvas captura páginas da web em imagens. Aqui está um novo requisito: faça capturas de tela de páginas da web e salve-as como arquivos PDF para download pelos usuários.
Usar o canvas para salvar páginas da web como arquivos PDF oferece suporte a vários domínios
textoRequisitos: O usuário clica em download, salva a página como um arquivo PDF e faz o download.
Ideia: Continue usando o Canvas para fazer capturas de tela e converter o conteúdo do canvas em arquivos PDF.
Primeiro precisamos apresentar o caminho de download do arquivo js jspdf.debug.js https://github.com/MrRio/jsPDF
Apresentando o arquivo js do canvas, a página inicial do site oficial do endereço de aquisição do arquivo js: http://html2canvas.hertzen.com/
<script type=text/javascript src=js/html2canvas.js></script><script type=text/javascript src=js/html2canvas.min.js></script><script type=text/javascript src=js /jspdf.debug.js></script>
código do botão div
<div id=down_pdf>Botão Exportar para PDF</div> <div class=sta-main>O div que precisa ser obtido como PDF</div>
código jsp
<script type=text/javascript>/* var downPdf = document.getElementById(down_pdf); */var downPdf = document.getElementById(down_pdf);$(#down_pdf).on(click, function() { var canvas2 = documento .createElement(canvas); let _canvas = document.querySelector('.sta-main'); parseInt(window.getComputedStyle(_canvas).width); var h = parseInt(window.getComputedStyle(_canvas) .height); //Amplie a tela em 2 vezes e coloque-a em um pequeno contêiner para lidar com o desfoque canvas2.width); = w * 2; tela2.altura = h * 2; px; var context = canvas2.getContext(2d); //Deslocamento do processo context.scale(1.5, 1.5); # fff) html2canvas( _canvas, { //Lidar com o problema de não obter informações de vários domínios do pdf entre domínios taintTest : false, useCORS : true, allowTaint : false, canvas : canvas2, dpi: 172, //Exportar clareza do PDF onrenderizado: function (canvas) { var contentWidth = canvas.width; var contentHeight = canvas.height; //Uma página do pdf exibe a altura da tela gerada pela página html; * 841.89 ; //Altura da página HTML sem pdf gerado var leftHeight = contentHeight; //deslocamento da página PDF var position = 0; //A largura e altura da tela gerada pela página html na imagem pdf (tamanho do papel a4 [595.28.841.89]) var imgWidth = 595.28; 'imagem/jpeg ', 1.0); var pdf = new jsPDF('', 'pt', 'a4'); //Existem duas alturas que precisam ser distinguidas, uma é a altura real da página html e a altura da página do pdf gerado (841.89) //Quando o conteúdo não excede o intervalo de exibição de a página pdf, nenhuma paginação é necessária if (leftHeight <pageHeight) { pdf.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight } else { while (leftHeight > 0) {); pdf.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight) leftHeight -= pageHeight; //Evite adicionar páginas em branco if (leftHeight > 0) { pdf.addPage(); pdf.save('Nome do PDF.pdf'); $('.sta-main').css(background, )})</script>Desta vez a página web é alterada para PDF, e a última captura de tela da página web é PNG, usando a mesma tecnologia, ambos usam Canvas para capturar a tela primeiro e depois converter o formato.
Existem também problemas como deslocamento, desfoque, domínio cruzado, etc., que podem ser resolvidos usando o código anterior.
A conversão de PDF tornará a cor de fundo preta. Basta usar o estilo CSS para alterar a cor de fundo.
Conversão perfeita para pdf.
O texto acima é todo o conteúdo deste artigo. Espero que seja útil para o estudo de todos. Também espero que todos apoiem a Rede VeVb Wulin.