imgタグの画像をBase64形式に変換するサンプルです。
サンプルソース
例)canvasのデータをjpeg形式としてBase64化する
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="utf-8"> <title>サンプル</title> <script> function getBase64(){ //img要素オブジェクトを取得する var obj = document.getElementById("img1"); //canvas要素を生成してimg要素を反映する var cvs = document.createElement('canvas'); cvs.width = obj.width; cvs.height = obj.height; var ctx = cvs.getContext('2d'); ctx.drawImage(obj, 0, 0); //canvas要素をBase64化する var data = cvs.toDataURL("image/png"); //d1要素に書き出す document.getElementById("d1").innerText = data; } </script> </head> <body> <img id="img1" src="inu.png"> <input type="button" id="btn1" value="ボタン" onclick="getBase64();"> <div id="d1"></div> </body> </html> |
- (結果例)
- ...
解説
- imgタグの画像をBase64形式に変換するには、一旦canvas要素に変換してからBase64に書き出します。
- 上記サンプルはローカル環境だと、セキュリティ(クロスドメイン制約)のため実行できません。(※Tainted canvases may not be exportedエラーが発生します。)
実行したい場合は、レンタルサーバー等にアップしてご確認ください。
pngでもdata:image/jpeg;になる。
コメントありがとうございます。
toDataURLに指定した型式がBase64文字列の先頭になるようです。
toDataURLの引数には画像と同じ形式を指定してください。
サンプルも修正しました。