繁体   English   中英

使用JavaScript创建base64编码图像

[英]Create base64 encoded images with JavaScript

由于图像是数据,我们可以将代码编写为

 <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUA AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO 9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" /> 

现在我的观点是:我们可以用javascript创建base64数据吗? 它有什么框架吗?

我的实际要求是我有一个像“牛”这样的字符串,我希望它作为一个图像。

注意:我不想要服务器调用它。 我知道我可以通过传递“Cow”作为参数来调用服务器端代码。 我的服务器端代码可以生成该图像,但我想通过JavaScript从浏览器中执行此操作。

您可以使用画布创建图像。 有许多画布框架可以帮助您。 然后,您可以将画布“导出”为base64字符串。

使用jCanvas尝试此示例:

HTML

<p>
  Result:
</p>
<p>
  <textarea id="result" cols="60" rows="10"></textarea>
</p>
<p>
  <input id="click" type="button" value="Convert to base64">
</p>
<p>
  Canvas<br><canvas id="myCanvas" width="100" height="100"/>
</p>

JavaScript的

$(function(){

  var canvas = document.getElementById("myCanvas");
  var ctx = canvas.getContext("2d");
  ctx.fillStyle = "#FF0000";
  ctx.fillRect(0, 0, 80, 80);

  $('#click').click(function() {
    $('#result').html($("canvas").getCanvasImage());
  });
});

演示

在此输入图像描述

 var element = new Image();
 element.src = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==";

如果您想为身体添加身份证明:

 document.body.appendChild(element);

您必须在要显示图像的父元素上使用appendChild。 它会自动加载。

我希望我的问题是正确的。 你想要的是实际的数据,而不是uri?

我从MuniR找到了这个小片段,我想这就是你想要的。

事情是我们似乎无法摆脱画布,用图像的大小创建它,绘制图像并使用画布对象来存储它! - 不一定使用它...希望它有所帮助,祝你好运

function getBase64FromImageUrl(url) {
    var img = new Image();

    img.setAttribute('crossOrigin', 'anonymous');

    img.onload = function () {
        var canvas = document.createElement("canvas");
        canvas.width =this.width;
        canvas.height =this.height;

        var ctx = canvas.getContext("2d");
        ctx.drawImage(this, 0, 0);

        var dataURL = canvas.toDataURL("image/png");

        alert(dataURL.replace(/^data:image\/(png|jpg);base64,/, ""));
    };

    img.src = url;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM