一種angular的方法級(jí)的緩存注解(裝飾器)
使用es6中裝裝飾器能做很多事情,今天分享一種在angular使用裝飾器進(jìn)行方法調(diào)用緩存的功能。
應(yīng)用場景是這樣的,在前端工作中,會(huì)有一些經(jīng)常使用的方法經(jīng)常被調(diào)用,但是這些方法每次調(diào)用都會(huì)占用很多的資源,比如網(wǎng)絡(luò)請(qǐng)求,數(shù)據(jù)統(tǒng)計(jì)功能,這些方法一般會(huì)隨著函數(shù)調(diào)用傳參的不同返回的結(jié)果不同。
因?yàn)槭褂眠^spring中的cache功能,感覺es中如果有spring cacheable注解就好了,在spring中注解使用如下:
@Cacheable(value="'accountCache_'+#userName")// 緩存名叫 accountCache_USERNAME public Account getAccountByName(String userName) { // @@@@ return acount; }
spring中的緩存時(shí)間是在配置文件中配置的,但是在前端一般我們需要針對(duì)不同的函數(shù)設(shè)置不同的緩存時(shí)間
因此 需要每次指定相應(yīng)的緩存時(shí)間
@cacheable(111) getSecondLeftMenu(topMenuId: number){ return 1111; }
于是我搞了一個(gè)支持 返回是Promise對(duì)象的緩存注解
export function cacheable(timeout:number) { return function (target: any, key: string, descriptor: any) { const originalMethod = descriptor.value; descriptor.value = function (...args: any[]) { //把傳入的參數(shù)和被調(diào)的函數(shù)名一起組成存儲(chǔ)的主鍵 const paramStr = args.map(a => JSON.stringify(a)).join(); const keyStr=key+"start$$"+(paramStr||"")+"-$$end"; let resultStr=localStorage.getItem(keyStr); if (!!resultStr) { let resultValue=JSON.parse(resultStr); let now=new Date() as any; //把緩存時(shí)的時(shí)間和當(dāng)前的時(shí)間進(jìn)行對(duì)比,如果沒有超時(shí),則直接返回 let old2=(new Date(resultValue.date)) as any; let delt=now - old2; if (delt<(timeout*1000)) { return Promise.resolve(resultValue.value); } } //超時(shí)時(shí),調(diào)用原方法,并記錄返回結(jié)果,這里我們的返回均是promise對(duì)象 var result = originalMethod.apply(this, args); result.then(data=>{ let dd={ date:new Date(), value:data } localStorage.setItem(keyStr,JSON.stringify(dd)) return Promise.resolve(data); },data=>{ return Promise.reject(data); }) return result; } return descriptor; } }
上述的代碼中,我們重點(diǎn)實(shí)現(xiàn)了返回值是Promise對(duì)象的函數(shù),因?yàn)樵谇岸斯ぷ髦校钫加觅Y源和需要緩存的是網(wǎng)絡(luò)請(qǐng)求,而且也極易影響用戶的體驗(yàn),因此我們重點(diǎn)關(guān)心了返回值是Promise的注解。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Angular使用ControlValueAccessor創(chuàng)建自定義表單控件
這篇文章主要介紹了Angular使用ControlValueAccessor創(chuàng)建自定義表單控件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03Angular在一個(gè)頁面中使用兩個(gè)ng-app的方法(二)
這篇文章主要介紹了Angular在一個(gè)頁面中使用兩個(gè)ng-app的方法(二),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02angular使用bootstrap方法手動(dòng)啟動(dòng)的實(shí)例代碼
本篇文章主要介紹了angular使用bootstrap方法手動(dòng)啟動(dòng)的實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07詳解angularJS動(dòng)態(tài)生成的頁面中ng-click無效解決辦法
這篇文章主要介紹了詳解angularJS動(dòng)態(tài)生成的頁面中ng-click無效解決辦法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-06-06Angular中ng-options下拉數(shù)據(jù)默認(rèn)值的設(shè)定方法
本篇文章主要介紹了Angular中ng-options下拉數(shù)據(jù)默認(rèn)值的設(shè)定方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06AngularJS轉(zhuǎn)換響應(yīng)內(nèi)容
這篇文章主要介紹了AngularJS轉(zhuǎn)換響應(yīng)內(nèi)容 的相關(guān)資料,需要的朋友可以參考下2016-01-01AngularJS使用ng-repeat和ng-if實(shí)現(xiàn)數(shù)據(jù)的刪選顯示效果示例【適用于表單數(shù)據(jù)的顯示】
這篇文章主要介紹了AngularJS使用ng-repeat和ng-if實(shí)現(xiàn)數(shù)據(jù)的刪選顯示效果,非常適用于表單數(shù)據(jù)的顯示使用,涉及ng-repeat和ng-if命令的相關(guān)使用技巧,需要的朋友可以參考下2016-12-12