純js實現(xiàn)無限空間大小的本地存儲
好久沒有寫博客了,想到2年前答應(yīng)要放出源代碼的也沒放出來,最近終于有空先把純js實現(xiàn)無限空間大小的本地存儲的功能開源了,
項目地址https://github.com/xueduany/localstore,
demo見http://xueduany.github.io/localstore/,
下面給大家簡單說說大概原理,具體細節(jié)和異常處理后面有機會在單獨說
先說下突破本地localStorage的原理,官方原話是這么說的http://www.w3.org/TR/2013/PR-webstorage-20130409/
所以你懂的,你可以利用多個子域名的localStorage是不互相依賴的性質(zhì),來通過多個子域名的localStorage來設(shè)計實現(xiàn)一個storePool,突破上限
那么,在實際API存儲的時候,就不是對本地localStorage的保存了
這有點類似一個Manager模式,就是你告訴倉庫管理員你要保存什么,倉庫管理員給你一把鑰匙,然后你拿著鑰匙去對應(yīng)的倉庫把你的東西托管起來,管理員再給你一個token憑證,以后你只要拿著這個憑證就可以把的保存的東西取出來
最終用戶不用care我的數(shù)據(jù)保存在哪里,只要實現(xiàn)類似localStorage的API即可
然后設(shè)計一個js對象來充當(dāng)倉庫管理員的角色即可,這個管理員需要支持有多少個token,對應(yīng)的保存的東西寄放在哪里,就是寄放在哪個子域名下的空間里面,那么我們需要設(shè)計實現(xiàn)這么一套數(shù)據(jù)結(jié)構(gòu)
對應(yīng)的key下面是存放它存在的倉庫的地址,以及保存時間,保存時間的概念是用來計算數(shù)據(jù)新鮮度的,即計算是否過期
所以我們首先要創(chuàng)建多個iframe,來加載多個域名下代理文件,通過HTML5的api postMessage或者之前老的頁面跨域方式互相交互,來通過這個代理的proxy來保存數(shù)據(jù)
在當(dāng)前主域名下保存,數(shù)據(jù)的key的存根,然后實際數(shù)據(jù)保存在各個子域名下
Ok,那么現(xiàn)在突破了存儲上限,我們要保存一個網(wǎng)頁下來,就要考慮把網(wǎng)頁相關(guān)的靜態(tài)資源都拉下來,對于網(wǎng)頁相關(guān)的資源,有包括js,css,這些都是文本,這些都簡單,只要一個ajax請求過,就可以拿到內(nèi)容,唯一要考慮的就是安全性就是跨域問題導(dǎo)致js拿不到響應(yīng)數(shù)據(jù),這里只要在CDN節(jié)點服務(wù)器上設(shè)置響應(yīng)頭為
即可,跨域得到內(nèi)容
js,就是<script src=”url”></script>這種只要改成<script>遠程拿到的內(nèi)容</script>即可,css,<link rel=”stylesheet” href=”url”>這種只要改成<style>內(nèi)容</style>即可
這里只要考慮能匹配到原來html的這些代碼塊即可,只要考慮一個問題,就是js的regexp默認(rèn)是貪婪模式,所以我們的正則要做到最小匹配,
然后找到html里面對應(yīng)的內(nèi)容,替換成為已經(jīng)保存在localStorage里面的內(nèi)容即可
那么對于圖片,如何獲得圖片的內(nèi)容呢?我們知道圖片是rawdata,2進制,首先我們要解決獲取圖片2進制流的問題
然后通過fileReader直接轉(zhuǎn)換成為base64,既可以保存在本地了,然后替換圖片的src從一個url變成一段base64的字符串即可
然后把整個網(wǎng)頁html里面對應(yīng)資源替換成為我們特殊標(biāo)記
LOCALSTORE標(biāo)記,然后通過遞歸查找算法,從各個子store取得內(nèi)容,還原平湊成為原來的完整html
然后直接通過document.write來還原原來的頁面
通過這種原理,你可以把一個網(wǎng)站離線化到本地,然后基于singlePage技術(shù),來實現(xiàn)不發(fā)任何請求的瀏覽,當(dāng)然了,這里面還有一些別的技術(shù)細節(jié)需要處理,具體有哪些坑,且聽我下回分解?。。?/p>
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
相關(guān)文章
setTimeout與setInterval在不同瀏覽器下的差異
setTimeout與setInterval是window對象的兩個非常神奇方法,用于實現(xiàn)定時或延時調(diào)用一個函數(shù)或一段代碼2010-01-01JS+CSS實現(xiàn)類似QQ好友及黑名單效果的樹型菜單
這篇文章主要介紹了JS+CSS實現(xiàn)類似QQ好友及黑名單效果的樹型菜單,涉及JavaScript結(jié)合鼠標(biāo)事件針對頁面元素CSS樣式的動態(tài)操作技巧,非常簡單實用,需要的朋友可以參考下2015-09-09js中頁面的重新加載(當(dāng)前頁面/上級頁面)及frame或iframe元素引用介紹
用JavaScript刷新上級頁面和當(dāng)前頁面在某些情況下還是比較實用的,感興趣的朋友可以了解下另外介紹一下frame或iframe元素的引用方法,希望本文對你有所幫助2013-01-01layui表格 返回的數(shù)據(jù)狀態(tài)異常的解決方法
今天小編就為大家分享一篇layui表格 返回的數(shù)據(jù)狀態(tài)異常的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09