2014-12-05 173 views
0

好吧,我即將結束一個項目,我遇到了一個小小的技術問題。爲了很容易修復它,我需要一種方法來獲取javascript中的html元素並將其編碼爲base64字符串?Base64編碼

我知道這是可能的帆布 - 因爲這是我現在的工作方式,但項目現在需要採取不同的方法來採取其他技術原因。

任何有關如何提取img src並將其編碼爲base64字符串的幫助或建議將非常棒。

似乎dataURL方法只適用於canvas?

+0

請看看這個[SO問題](http://stackoverflow.com/questions/6150289/how-to-convert-image-into-base64-string-using -javascript)。我認爲應該有一個適合你的答案。 – AWolf 2014-12-05 00:18:27

+0

我瞭解您的帖子中概述的畫布方法...但由於我的項目的要求,我不能在這種情況下使用畫布...因此這個問題。 – user61026 2014-12-05 07:31:16

回答

0

的WOM(窗口對象模型)配備了兩種方法:ATOB和BTOA

你可以稱他們爲: window.atob(str) 或只是 btoa(str)

BTOA編碼字符串BASE-64 ATOB解碼Base-64中的字符串

+0

所以我正確地說,這將編碼圖像src? – user61026 2014-12-05 07:29:01

+0

@ user61026如果圖像源是一個字符串,是的 - 它會。 – SirPython 2014-12-05 20:23:20

0

我不完全確定自己是否正確理解它,但是如果您想要從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>