好吧,我即將結束一個項目,我遇到了一個小小的技術問題。爲了很容易修復它,我需要一種方法來獲取javascript中的html元素並將其編碼爲base64字符串?Base64編碼
我知道這是可能的帆布 - 因爲這是我現在的工作方式,但項目現在需要採取不同的方法來採取其他技術原因。
任何有關如何提取img src並將其編碼爲base64字符串的幫助或建議將非常棒。
似乎dataURL方法只適用於canvas?
好吧,我即將結束一個項目,我遇到了一個小小的技術問題。爲了很容易修復它,我需要一種方法來獲取javascript中的html元素並將其編碼爲base64字符串?Base64編碼
我知道這是可能的帆布 - 因爲這是我現在的工作方式,但項目現在需要採取不同的方法來採取其他技術原因。
任何有關如何提取img src並將其編碼爲base64字符串的幫助或建議將非常棒。
似乎dataURL方法只適用於canvas?
我不完全確定自己是否正確理解它,但是如果您想要從html中編碼圖像,則可以在下面的演示中進行操作。
那裏我創建了一個只在你的js中可用的畫布元素。然後在「虛擬」畫布中繪製圖像,之後您可以使用toDataURL()
來執行base64編碼。
在演示中,我已通過將該圖像輸出回輸出格來測試編碼。
我使用的標記中的圖像是base64編碼,因爲我在ctx.drawImage(...)
上有過交叉原點問題,但是如果您使用來自相同原點的圖像應該沒有問題。
你可以在這裏找到相同的演示jsFiddle。
$(function() {
var $sourceImg = $('#sourceImg');
var $canvas = $('<canvas/>');
var $out = $('#output');
$canvas.prop({"width": $out.width(), "height": $out.height()});
var ctx=$canvas.get(0).getContext("2d");
//console.log($sourceImg.prop('src'));
// draw image on canvas
var img = new Image(300,300);
img.src = $sourceImg.prop('src');
ctx.drawImage(img,0,0);
// convert canvas to base64 image
var base64img = $canvas.get(0).toDataURL();
//console.log(base64img);
// test if encoding is correct
var img = new Image();
img.src = base64img;
$("#output").append(img);
});
#output {
display: block;
width: 100%;
height: 500px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
<!-- used base64 encoded image because of security error with cross-origin image directly from http://placehold.it/300x300 -->
<img src="" id="sourceImg"/>
<div id="output">
<h2>test ouput of base64 encoded image:</h2>
</div>
</div>
請看看這個[SO問題](http://stackoverflow.com/questions/6150289/how-to-convert-image-into-base64-string-using -javascript)。我認爲應該有一個適合你的答案。 – AWolf 2014-12-05 00:18:27
我瞭解您的帖子中概述的畫布方法...但由於我的項目的要求,我不能在這種情況下使用畫布...因此這個問題。 – user61026 2014-12-05 07:31:16