如何将元素的重复线性渐变转换为 base64 图像或任何其他格式?

How to convert repeating-linear-gradient of an element to a base64 image or any other format?

我似乎找不到将 repeat-linear-gradient 转换为 base64 图像格式的方法。

background-image: repeating-linear-gradient(-45deg, transparent, transparent 5px, white 5px, white 10px);

我的问题是我想用 html2canvasjsPDF 打印一个 HTML 页面,但是因为 html2canvas 不支持 support repeat-linear-gradient,想知道有没有办法把值转成base64

此外,由于背景图像是由 gantt-chart 库渲染的,我无法更改它的设置方式

由于它是一个重复渐变,您可以确定可以导出为图像的最小部分,这样您就可以通过重复此图像获得相同的背景。

您正在处理 +-45deg,最后一个色标是 10px,所以最小的部分是 10px*sqrt(2) = 14.14px 的高度和宽度:

.box {
  height: 14.14px;
  width: 14.14px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}
<div class="box"></div>

您将其另存为图像,并使用任何将 png 转换为 base64 的在线工具:

.box {
  height: 100px;
  margin: 5px;
  background: url('');
}
<div class="box"></div>

<div class="box" style="background:repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px)"></div>


对于动态解决方案,我将考虑 this previous answer

中使用的代码

var box = document.querySelector(".box");

domtoimage.toPng(box)
  .then(function(dataUrl) {
    console.log(dataUrl)
    var image = new Image();
    image.onload = function() {
        document.body.appendChild(image);
    };
    image.src = dataUrl;
  })
.box {
  height: 100px;
  margin:5px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}
<script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>

<div class="box"></div>

也喜欢这个:

var box = document.querySelector(".box");

domtoimage.toPng(box)
  .then(function(dataUrl) {
    console.log(dataUrl);
    document.querySelector(".alt").style.background='url('+dataUrl+')';
  })
.box {
  height: 14.14px;
  width: 14.14px;
  background: repeating-linear-gradient(-45deg, transparent, transparent 5px, blue 5px, blue 10px);
}

.alt {
  height:100px;
  margin:5px;
}
<script type="text/javascript" src="https://css-challenges.com/wp-content/themes/ronneby_child/js/dom-to-image.js"></script>

<div class="box"></div>

<div class="alt"></div>