如何優(yōu)雅的用localStorage緩存圖片

遇到一個(gè)項(xiàng)目栗柒,甲方對(duì)頁面打開時(shí)間要求特別高震叮,于是萌生出把資源緩存到本地的想法。本地儲(chǔ)存數(shù)據(jù)用的是localStorage农尖,摸索了一下屉符,便出現(xiàn)了下面的js:

//localFile.js
//版本控制
var script = document.getElementsByTagName("script");
for (var i = 0; i < script.length; i++) {
    if (script[i].getAttribute("version")) {
        if (script[i].getAttribute("version") != localStorage["version"]) {
            localStorage.clear();
            localStorage["version"] = script[i].getAttribute("version");
        }
    }
}

//js
function loadJs(jsUrl) {
    if(!localStorage[jsUrl]){
        var xmlhttp=new XMLHttpRequest();
        xmlhttp.open("GET",jsUrl,false);
        xmlhttp.send();
        localStorage[jsUrl] = xmlhttp.responseText;
    }
    return localStorage[jsUrl]
}

//img
function loadImg(img) {
    if (img.getAttribute("lsrc")) {
        if (!localStorage[img.getAttribute("lsrc")]) {
            var x = new XMLHttpRequest();
            x.responseType = "blob";
            x.open("get", img.getAttribute("lsrc"), true);
            x.onreadystatechange = function () {
                if (x.readyState == 4) {
                    var reader = new FileReader();
                    reader.readAsDataURL(x.response);
                    reader.onload = function () {
                        localStorage[img.getAttribute("lsrc")] = this.result;
                        img.src = this.result;
                    }
                }
            }
            x.send();
        }
        else {
            img.src = localStorage[img.getAttribute("lsrc")];
        }
    }
}

//CSS
function loadCss(url) {
    if(!localStorage[url]){
        var xmlhttp=new XMLHttpRequest();
        xmlhttp.open("GET",url,false);
        xmlhttp.send();
        localStorage[url] = xmlhttp.responseText;
    }
    var s = document.createElement("style");
    s.innerHTML = localStorage[url];
    document.getElementsByTagName("head")[0].appendChild(s)
}

調(diào)用方法:

引入js:

<script src="js/localFile.js" version=12></script>

version為版本號(hào)剧浸,當(dāng)版本號(hào)改變的時(shí)候,js會(huì)清空localStorage矗钟,執(zhí)行的時(shí)候會(huì)重新載入全部資源唆香。

載入js:

<script>eval(loadJs("js/vue.min.js"));</script>

載入css:

<script>loadCss("style.css")</script>

載入圖片

< img lsrc="img/top.png" src="" onerror="loadImg(this)" class="top" >

圖片src為空,真實(shí)地址寫在lsrc屬性里吨艇。當(dāng)圖片讀取""地址的時(shí)候躬它,會(huì)出錯(cuò),調(diào)用onerror從而執(zhí)行函數(shù)載入圖片數(shù)據(jù)东涡。

更加喪心病狂

    <script version=12>//js/localFile.js
        var script = document.getElementsByTagName("script");
        for (var i = 0; i < script.length; i++){
            if (script[i].getAttribute("version")) {
                if (script[i].getAttribute("version") != localStorage["version"]) {
                    localStorage.clear();
                    localStorage["version"] = script[i].getAttribute("version");
                }
            }
        }
        if(!localStorage["js/localFile.js"]){
            var xmlhttp=new XMLHttpRequest();
            xmlhttp.open("GET","js/localFile.js",false);
            xmlhttp.send();
            localStorage["js/localFile.js"] = xmlhttp.responseText;
        }
        eval(localStorage["js/localFile.js"]);
    </script>

把這個(gè)js也寫入localStorage冯吓,記得這個(gè)要優(yōu)先執(zhí)行~
實(shí)測(cè):


A6095732-D196-4503-A989-A3BF44539331.png
timg.jpeg
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市软啼,隨后出現(xiàn)的幾起案子桑谍,更是在濱河造成了極大的恐慌,老刑警劉巖祸挪,帶你破解...
    沈念sama閱讀 211,561評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锣披,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)雹仿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門增热,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人胧辽,你說我怎么就攤上這事峻仇。” “怎么了邑商?”我有些...
    開封第一講書人閱讀 157,162評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵摄咆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我人断,道長(zhǎng)吭从,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,470評(píng)論 1 283
  • 正文 為了忘掉前任恶迈,我火速辦了婚禮涩金,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘暇仲。我一直安慰自己步做,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評(píng)論 6 385
  • 文/花漫 我一把揭開白布奈附。 她就那樣靜靜地躺著全度,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桅狠。 梳的紋絲不亂的頭發(fā)上讼载,一...
    開封第一講書人閱讀 49,806評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音中跌,去河邊找鬼。 笑死菇篡,一個(gè)胖子當(dāng)著我的面吹牛漩符,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播驱还,決...
    沈念sama閱讀 38,951評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼嗜暴,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了议蟆?” 一聲冷哼從身側(cè)響起闷沥,我...
    開封第一講書人閱讀 37,712評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎咐容,沒想到半個(gè)月后舆逃,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,166評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評(píng)論 2 327
  • 正文 我和宋清朗相戀三年路狮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了虫啥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,643評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡奄妨,死狀恐怖涂籽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情砸抛,我是刑警寧澤评雌,帶...
    沈念sama閱讀 34,306評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站直焙,受9級(jí)特大地震影響景东,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜箕般,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評(píng)論 3 313
  • 文/蒙蒙 一耐薯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧丝里,春花似錦曲初、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至幌绍,卻和暖如春颁褂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背傀广。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工颁独, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人伪冰。 一個(gè)月前我還...
    沈念sama閱讀 46,351評(píng)論 2 360
  • 正文 我出身青樓誓酒,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親贮聂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子靠柑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 在線閱讀 http://interview.poetries.top[http://interview.poetr...
    程序員poetry閱讀 114,313評(píng)論 24 450
  • 1.幾種基本數(shù)據(jù)類型?復(fù)雜數(shù)據(jù)類型?值類型和引用數(shù)據(jù)類型?堆棧數(shù)據(jù)結(jié)構(gòu)? 基本數(shù)據(jù)類型:Undefined、Nul...
    極樂君閱讀 5,502評(píng)論 0 106
  • 前端開發(fā)面試知識(shí)點(diǎn)大綱: HTML&CSS: 對(duì)Web標(biāo)準(zhǔn)的理解吓懈、瀏覽器內(nèi)核差異歼冰、兼容性、hack耻警、CSS基本功:...
    秀才JaneBook閱讀 2,341評(píng)論 0 25
  • 時(shí)間已經(jīng)過去四五年隔嫡,好多事情在漸漸變得模糊甸怕,不再那么清晰。但兒子對(duì)曾經(jīng)的小狗點(diǎn)點(diǎn)的記憶畔勤,依然可怕的清晰蕾各。一次的失...
    __天道酬勤__閱讀 465評(píng)論 5 13
  • 1:android stduio +SDK +JDK(as 的配置就不多說了) 2:下載node.js 推薦最新版...
    palas貓閱讀 2,559評(píng)論 0 1