2016-02-13 63 views
3

試圖加載&將圖像檢索到local storage或從localstorage檢索圖像。內容安全不是我想的問題。使用localStorage存儲和檢索PNG時的空白圖像

某處的代碼破壞了未正確存儲在本地存儲器中的圖像或未正確加載本地存儲器中的圖像。

下面是檢查圖像是否可從localstorage獲取的代碼。如果可以從會話中獲得,則從本地存儲中獲取。否則從URL中獲取並顯示圖像,並存儲在本地存儲中。

下面的代碼將得到執行,在pagebeforecreate

var dataImage = localStorage.getItem('ses_image'); 

    var img = $('<img crossorigin="anonymous" width="100%" height="100%" id="img_menu-item" style="height: 100%;width:100%">'); 
    jQuery('#pg_home_content').append(img); 

    if(dataImage){ 
     bannerImg = document.getElementById('img_menu-item'); 
     bannerImg.src = dataImage; 
     jQuery('#pg_home_content').append(bannerImg); 
    }else{ 
     img.attr('src', 'http://example.com/myimage.png'); 
     bannerImage = document.getElementById('img_menu-item'); 
     bannerImage.setAttribute('crossOrigin', 'anonymous'); 
     imgData = getBase64Image(bannerImage); 
     localStorage.setItem('ses_image', imgData); 
    } 

getBase64Image

function getBase64Image(img) { 

    var canvas = document.createElement("canvas"); 
    canvas.width = img.width; 
    canvas.height = img.height; 

    var ctx = canvas.getContext("2d"); 
    ctx.drawImage(img, 0, 0); 
    var dataURL = canvas.toDataURL("image/png"); 

    return dataURL; 
} 

當我做console.log(dataURL)它會產生下面的輸出,我想有些不妥......

 

第一次圖像被加載,從第二次以後,我得到一個空白圖像...不知道我失蹤了什麼?

+0

在'console'登錄任何錯誤? – guest271314

+0

@ guest271314不,控制檯上沒有錯誤。 – Malaiselvan

+0

在調用'.toDataURL()'的時候嘗試不包含''image/png「'? – guest271314

回答

1

將圖像寫入本地存儲器時圖像尚未完全加載。一個空白圖像被存儲在本地存儲器中,並在隨後的訪問中被檢索到。

爲了確保在本地寫入圖像之前加載圖像,請爲該圖像創建一個onload事件處理程序。

在你的代碼,更改:

img.attr('src', 'http://example.com/myimage.png'); 
    bannerImage = document.getElementById('img_menu-item'); 
    bannerImage.setAttribute('crossOrigin', 'anonymous'); 
    imgData = getBase64Image(bannerImage); 
    localStorage.setItem('ses_image', imgData); 

到:

console.log('loaded from url'); 
    bannerImage = document.getElementById("img_menu-item"); 
    bannerImage.setAttribute('crossOrigin', 'anonymous'); 

    // set the source of the image, equivalent to img.attr('src',...), but 
    // slightly more performant 
    img[0].src = "http://demo.jeema.org/mob20/media/com_jeemasmsmobile/menuicons/book.png"; 
    // delay writing to localstorage, until the image loads completely: 
    img[0].onload = function() { 
     imgData = getBase64Image(bannerImage); 
     console.log('writing to local storage:\n' + imgData); 
     localStorage.setItem('ses_image', imgData); 
     console.log('image stored'); 
    } 
+0

謝謝。我相信而不是'img [0]'在我的情況下是'bannerImage'。現在圖像被加載,但是我得到了一個不同的問題(很高興提出一個單獨的線程)因爲我在一個循環內調用這個方法,並且onload是'async',所以圖像總是存儲在循環中的最後一個變量中。 – Malaiselvan

+0

不客氣。你能解釋你遇到的第二個問題嗎? – Stiliyan

+1

提出了另一個線程http://stackoverflow.com/questions/35387534/calling-image-onload-inside-a-loop-with-global-variable – Malaiselvan