2014-12-05 3 views
0

Хорошо, я приближаюсь к концу проекта, и я столкнулся с небольшой техникой. Чтобы исправить это легко, мне нужен способ взять элемент html в javascript и закодировать его в строку base64?Base64 encoding

Я знаю, что это возможно с холстом - так как я работаю в данный момент, но сейчас проект требует другого подхода по другим техническим причинам.

Любая помощь или рекомендации о том, как извлечь img src и закодировать его в строку base64, будет потрясающе.

Кажется, что метод dataURL работает только с холстом ??

+0

Пожалуйста, посмотрите на это [SO вопрос] (http://stackoverflow.com/questions/6150289/how-to-convert-image-into-base64-string-using -javascript). Я думаю, что для вас должен быть ответ. – AWolf

+0

Я понимаю метод холста, как указано в вашем сообщении ... но из-за требований моего проекта я не могу использовать холст в этом экземпляре ... следовательно, вопрос. – user61026

ответ

0

WOM (Окно Object Model) поставляется с двумя методами: atob и btoa

Вы можете назвать их как: window.atob(str) или просто btoa(str)

btoa кодирует строку Base-64 atob декодирует строку в Base-64

+0

так я прав, говоря, что это будет кодировать изображение src? – user61026

+0

@ user61026 Если источником изображения является строка, да - это будет. – SirPython

0

Я не совсем уверен, правильно ли я это понял, но если вы хотите кодировать изображение из своего html, вы можете сделать это, как в демо ниже.

Там я создал элемент холста, который доступен только в js. Затем нарисуйте свое изображение на этом «виртуальном» холсте, а затем вы можете использовать toDataURL(), чтобы сделать кодировку base64.

В демоверсии я проверил кодирование, вернув это изображение обратно в выходной div.

Изображение в разметке, которую я использовал, кодируется 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>