0

我想将html转换为png。

这是我的html

<!DOCTYPE html>
<html>
<head>
  <style type="text/css">* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }

  main {
    width: 600px;
    margin: 100px auto;
  }

  header {
    width: 100%;
    height: auto;
    background-color: red;
    background-size: cover;
    background-repeat: no-repeat;
  }

  header .content {
    width: 80%;
    margin-left: 10%;
    margin-right: 10%;
    display: flex;
    padding: 40px 0;
  }

  .content .column {
    width: 25%;
    margin: auto;
    text-align: center;
  }

  .content .column.lfp-logo {
    width: 30%;
  }

  .content .column img {
    width: 80%;
    height: auto;
  }
  </style>
</head>
<body>
<main>
  <header>
    <div class="content">
      <div class="column"><img
        src="https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg"></div>
      <div class="column lfp-logo"><img
        src="https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg"></div>
      <div class="column"><img
        src="https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg"></div>
    </div>
  </header>
</main>
</body>
</html>

这是 jsfiddle 示例。这实际上是我需要在我的 png 文件jsfiddle中得到的

我尝试使用wkhtmltoimage,我得到了这张图片在此处输入图像描述

我还尝试使用phantomjs并获取此图像 在此处输入图像描述 ,我将 phantomjs 与 nodejs 模块一起使用webshot

谁能建议我将html渲染为png图像的方法。我不需要动态 html。我要渲染的只是静态的。

更新。添加了用于生成图像的代码

const pug = require('pug');
const child_process = require('child_process');
const fs = require('fs');
const webshot = require('webshot');

const options = {
    data: {
        images: {
            header: 'https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg',
            team1: 'https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg',
            team2: 'https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg',
            competition: 'https://cdn.shopify.com/s/files/1/1237/5652/products/spiderman_3_compression_shirt_3_small.jpg'
        }
    }
};

const html = pug.renderFile('./template/next.pug', options);

console.log(html); // this is html

// webshot with wkhtmltoimage
child_process.exec(`echo "${html}" | wkhtmltoimage --width 600 --disable-smart-width - export/out.png`, (err) => {
    console.log(err);
});

// webshot with phantomjs
webshot(html, 'hello_world.png', {siteType:'html'}, function(err) {
    console.log(err);
});
4

1 回答 1

-1

我会说做这样的事情。使用html2canvas,您可以轻松快速地完成它。

    convert_to_img = function (do_download) {
  html2canvas(document.getElementById("contenedor_chimichangas"), {
    //onrender devuelve el canvas para hacerle los retoques necesarios
    onrendered: function (canvas) {//sombra aqui, sombra allí!! 
      var context = canvas.getContext('2d');//context from originalCanvas
      var data_image = canvas.toDataURL("image/png"); //cogemos la url de la imagen sin tratar
      //añadimos la url en una imagen para poder tratarla y redimensionarla
      var image_edicion = $("<img/>", {
        id: "image",
        src: data_image
      }).appendTo($("#show_img").empty());
        //if we click download:
        if(do_download === true){
          Canvas2Image.saveAsPNG(new_canvas);
        }
      });

    },

  });
}

js逐行记录。;D

于 2017-07-05T11:25:27.000 回答