4

Ajax リクエストを使用して、 localStorageに画像を保存しようとしています。

<!DOCTYPE html>
<html>
    <head>
        <title>test</title>
        <script type="text/javascript">
            window.onload = function() {
                var xmlhttp;
                if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
                    xmlhttp = new XMLHttpRequest();
                }
                else {// code for IE6, IE5
                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
                }
                xmlhttp.onreadystatechange=function() {
                    if (xmlhttp.readyState==4 && xmlhttp.status==200) {
                        var storedImage;
                        if (localStorage.getItem('imgtest')) {
                            storedImage = localStorage.getItem('imgtest');
                            alert("get");
                        }
                        else {
                            storedImage = xmlhttp.responseText;
                            localStorage.setItem('imgtest',storedImage);
                            alert("set");
                        }
                        document.getElementById("test").style.backgroundImage = 'data:image/png;base64,' + storedImage;
                    }
                }
                xmlhttp.open("GET","img.png");
                xmlhttp.setRequestHeader("Content-type","image/png");
                xmlhttp.send();
            }
        </script>
    </head>
    <body>
        <div id="test" style="width: 100px; height: 100px;"></div>
    </body>
</html>

ストリームを保存できますが、画像が表示されません。

エンコーディングのせいかもしれませんが、わかりません。私が間違っていること、またはこれを行うためのより良い方法があるかどうか教えてもらえますか?

4

2 に答える 2

2

次のように url() を試しましたか:

document.getElementById("test").style.backgroundImage = 'url(data:image/png;base64,' + storedImage + ')';

于 2012-12-05T16:03:34.550 に答える
0

POST でリクエストを実行しようとしましたか?

于 2012-12-05T14:50:04.977 に答える