使用图像源进行文件输入

时间:2016-10-27 10:09:06

标签: javascript jquery html src

在我的应用程序中,我使用html2canvas 文本转换为图像(此部分工作正常)

是否可以使用src img id="image-src" input id="file-input"进行上传?

<input type="file" id="file-input">

这是img src在文字转换到图像时的样子

<img src="" id="image-src">

这是转换屏幕截图的功能:

  function updateImage() {
    html2canvas(tallTweets, {
      onrendered: function(canvas) {
        var screenshot = canvas.toDataURL("image/png");
        screenshotImg.setAttribute("src", screenshot);
      }
    });
  };

2 个答案:

答案 0 :(得分:1)

只需使用普通输入字段即可。 然后它取决于你想再次使用图像的位置。

&#13;
&#13;
var screenshot = "";

var inputElement = document.getElementById("foo");
inputElement.value = screenshot;




document.getElementById("myImage").src = inputElement.value;
&#13;
<input type="text" id="foo" />
<br /><br />
<img id="myImage" />
&#13;
&#13;
&#13;

再次加载,你可以再次加载这个字符串,然后执行:

imageElement.src = base64String;

您可能需要通过服务器上的URI访问该图像。 像这样:http://example.com/uploads/myImage.jpg

然后你可以处理base64字符串服务器端(php,c#,java,python等)并将其保存为文件。

PHP示例,引自此处:

How to save a PNG image server-side, from a base64 data string

$data = '';
list($type, $data) = explode(';', $data);
list(, $data)      = explode(',', $data);
$data = base64_decode($data);
file_put_contents('/tmp/image.png', $data);

答案 1 :(得分:0)

为什么要尝试上传已经作为base64代码的文件?您可以传递代码,将其转换为文件并直接保存。