摘要:前言是一款極輕量的使用存儲(chǔ)代碼的工具??缬蚓彺鏁?huì)默認(rèn)使用請(qǐng)求待緩存的資源,如果跨域則會(huì)請(qǐng)求出錯(cuò)。會(huì)以格式存儲(chǔ)代碼,例如所以和有一個(gè)發(fā)生變化,都會(huì)引起重新請(qǐng)求并存儲(chǔ)。
前言
betty.js是一款極輕量的、使用localStorage存儲(chǔ)Javascript代碼的工具。市面上已經(jīng)有很多類(lèi)似的工具:比如餓了么團(tuán)隊(duì)最近發(fā)布的bowl.js,微信團(tuán)隊(duì)的MOON(未開(kāi)源),以及這個(gè)想法的鼻祖basket.js。
但為何還要“重復(fù)造輪子”?是因?yàn)?b>betty.js她足夠輕量,足夠簡(jiǎn)潔易用,足夠具有擴(kuò)展性,壓縮后的min.betty.js只有1KB!使得你可以直接以inline引入的方式(這也是推薦的引入方式)將betty用到你的項(xiàng)目里。
三年前就想著將Javascript的代碼存儲(chǔ)到LS里,在百度工作的時(shí)候曾寫(xiě)出一個(gè)基于mod.js的存儲(chǔ)工具mocket.js,它的思想是動(dòng)態(tài)分析項(xiàng)目依賴(lài),本地沒(méi)有存儲(chǔ)過(guò)的JS再去網(wǎng)絡(luò)請(qǐng)求再存儲(chǔ)下來(lái),這也順利應(yīng)用到百度的部分項(xiàng)目里。
但為何不直接開(kāi)源mocket.js,就是因?yàn)?b>betty不依賴(lài)任何組件,是一個(gè)獨(dú)立的極其輕量的小工具。當(dāng)然,可以借助betty.js來(lái)擴(kuò)展實(shí)現(xiàn)mocket.js動(dòng)態(tài)分析組件的思想。
好了,廢話(huà)這么多,接下來(lái)是介紹文檔:
安裝npm install betty.js
拷貝min.betty.js的代碼,使用inline的方式引入項(xiàng)目里:
如果你的項(xiàng)目基于FIS,可以這么引入:
示例 方式一:var betty = Betty({ uri: "/path/min.allLib.js", key: "allLib", noCache: false, xDomain: false }, function() { // your code... })方式二:
var betty = Betty({ uri: "/path/min.allLib.version.js", key: "allLib", noCache: false, xDomain: false }); betty.apply(function() { // your code... }) betty.apply(function() { // your others code... })
以上兩種方式的代碼執(zhí)行一遍之后,min.allLib.js的內(nèi)容就會(huì)被betty存儲(chǔ)到localStorage里,第二次執(zhí)行時(shí)就不會(huì)從網(wǎng)絡(luò)請(qǐng)求min.allLib.js,直接從緩存中讀取并執(zhí)行。
至于為何除了第一種寫(xiě)法,還支持了第二種寫(xiě)法?是因?yàn)樵谇岸斯こ汤?,可以考慮把定義betty的操作放到通用的layout里,把betty.apply寫(xiě)進(jìn)每個(gè)頁(yè)面對(duì)應(yīng)的js文件里。
當(dāng)然,你可以自由選擇自己的喜好。
跨域緩存betty.js會(huì)默認(rèn)使用Ajax請(qǐng)求待緩存的JS資源,如果跨域則會(huì)請(qǐng)求出錯(cuò)。這時(shí)候你需要設(shè)置betty padding和xDomain來(lái)讓跨域請(qǐng)求JS資源被支持:
index.html
min.allLib_with_padding.js
betty.store(function() { // your code... })
注意:
請(qǐng)?jiān)O(shè)置xDomain為true
請(qǐng)?jiān)诖彺娴腏S文件中設(shè)置betty padding,如以上的betty.store(....)
請(qǐng)?jiān)O(shè)置betty為全局變量
版本管理betty.js絕對(duì)依賴(lài)uri和key來(lái)管理JS版本。如果你的代碼需要更新,請(qǐng)更換uri的值,新的JS就會(huì)被請(qǐng)求,然后代碼內(nèi)容會(huì)被重新存儲(chǔ)到LocalStorage里,并且會(huì)刪掉舊版本的代碼。
betty.js會(huì)以BETTY:{key}:{uri}格式存儲(chǔ)JS代碼,例如:
BETTY:allLib:/path/min.allLib.version.js
所以key和uri有一個(gè)發(fā)生變化,都會(huì)引起重新請(qǐng)求并存儲(chǔ)。
API Betty配置betty
var betty = Betty({config, callback[option]})
config:
uri和key必須設(shè)置
noCache: 設(shè)置不緩存,默認(rèn)為false
xDomain: 設(shè)置跨域緩存,默認(rèn)false,詳見(jiàn)[跨域緩存]
betty.store添加存儲(chǔ)的代碼
betty.store(function() { ... })betty.apply
執(zhí)行依賴(lài)緩存的代碼
betty.apply(function() { ... })betty.remove
移除緩存的代碼
betty.remove("allLib")關(guān)于緩存CSS
目前還不支持,也不建議隨意緩存CSS內(nèi)容,還是建議直接在head里引入CSS,主要是基于以下的考慮:
動(dòng)態(tài)插入CSS會(huì)使頁(yè)面閃動(dòng)
CSS樣式順序管理問(wèn)題
當(dāng)然,一些不在首屏展示的CSS可以被緩存,但建議將其轉(zhuǎn)換成JS文件合并到你的min.allLib.js中,可以借助這個(gè)小工具addcss:
addcss("a{color: red,font-size: 12px}")
如果你使用FIS,可以這么處理:
addcss(__inline("style.css"))原始文檔
https://binnng.github.io/betty.js
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/61823.html
摘要:前言是一款極輕量的使用存儲(chǔ)代碼的工具??缬蚓彺鏁?huì)默認(rèn)使用請(qǐng)求待緩存的資源,如果跨域則會(huì)請(qǐng)求出錯(cuò)。會(huì)以格式存儲(chǔ)代碼,例如所以和有一個(gè)發(fā)生變化,都會(huì)引起重新請(qǐng)求并存儲(chǔ)。 前言 betty.js是一款極輕量的、使用localStorage存儲(chǔ)Javascript代碼的工具。市面上已經(jīng)有很多類(lèi)似的工具:比如餓了么團(tuán)隊(duì)最近發(fā)布的bowl.js,微信團(tuán)隊(duì)的MOON(未開(kāi)源),以及這個(gè)想法的鼻祖ba...
摘要:性能卓越的模板引擎簡(jiǎn)潔的模版語(yǔ)法,簡(jiǎn)單的,關(guān)鍵還能前后端共用模板,簡(jiǎn)直就是前端開(kāi)發(fā)利器。是由阿里巴巴部門(mén)推出的矢量圖標(biāo)管理網(wǎng)站。是一個(gè)簡(jiǎn)單的設(shè)備檢測(cè)工具。 artTemplate 性能卓越的 js 模板引擎 簡(jiǎn)潔的模版語(yǔ)法,簡(jiǎn)單的API,關(guān)鍵還能前后端(Nodejs)共用模板,簡(jiǎn)直就是前端開(kāi)發(fā)利器。今天有個(gè)想法,把a(bǔ)rtTemplate封裝下,模版render后給input等注冊(cè)幾個(gè)事...
摘要:不是很安全,別人可以分析存放在本地的并進(jìn)行欺騙,考慮到安全應(yīng)當(dāng)使用。因此不是一種持久化的本地存儲(chǔ),僅僅是會(huì)話(huà)級(jí)別的存儲(chǔ)。用于持久化的本地存儲(chǔ),除非主動(dòng)刪除數(shù)據(jù),否則數(shù)據(jù)是永遠(yuǎn)不會(huì)過(guò)期的。 前言 總括:詳細(xì)講述Cookie,LocalStorge,SesstionStorge的區(qū)別和用法。 人生如畫(huà),歲月如歌。 原文博客地址:Javascript本地存儲(chǔ)小結(jié) 知乎專(zhuān)欄&&簡(jiǎn)書(shū)專(zhuān)題:前端...
摘要:本地存儲(chǔ)的方案?jìng)鹘y(tǒng)把信息存儲(chǔ)到客戶(hù)端的瀏覽器中但是項(xiàng)目服務(wù)器端也是可以獲取的把信息存儲(chǔ)到服務(wù)器上的服務(wù)器存儲(chǔ)永久存儲(chǔ)在客服端的本地。 在客戶(hù)端運(yùn)行的js是不能操作用戶(hù)電腦磁盤(pán)中的文件的(這是為了保護(hù)客戶(hù)端運(yùn)行的安全)。 1、js中的本地存儲(chǔ): 使用js向?yàn)g覽器的某一個(gè)位置中存儲(chǔ)一些內(nèi)容,瀏覽器即使關(guān)閉了,存儲(chǔ)的信息也不會(huì)銷(xiāo)毀,當(dāng)在重新打開(kāi)瀏覽器的時(shí)候我們依然可以獲取到上一次存儲(chǔ)的信息。...
閱讀 2040·2021-09-30 09:47
閱讀 714·2021-09-22 15:43
閱讀 1996·2019-08-30 15:52
閱讀 2445·2019-08-30 15:52
閱讀 2556·2019-08-30 15:44
閱讀 919·2019-08-30 11:10
閱讀 3380·2019-08-29 16:21
閱讀 3305·2019-08-29 12:19