AngularJS中的緩存使用
緩存篇
一個緩存就是一個組件,它可以透明地儲存數據,以便以后可以更快地服務于請求。多次重復地獲取資源可能會導致數據重復,消耗時間。因此緩存適用于變化性不大的一些數據,緩存能夠服務的請求越多,整體系統(tǒng)性能就能提升越多。
$cacheFactory與緩存對象
$cacheFactory是一個為Angular服務生產緩存對象的服務。要創(chuàng)建一個緩存對象,可以使用$cacheFactory通過一個ID和capacity。其中,ID是一個緩存對象的名稱,capacity則是描述緩存鍵值對的最大數量。舉個生動的例子,$cacheFactory就是包租婆,她有一棟樓,里面有大大小小的房子可以出租,只要你給夠錢,包租婆就會把房子租給你(獲得緩存對象),這個房子包括了它的房號(ID)和房間的大小(capacity-容量)。
var myCache = $cacheFactory('myCache');
其中,緩存對象擁有以下幾種方法
1. myCache.info() 返回緩存對象的ID,尺寸和選項
2. myCache.put() 新值鍵值對并放入緩存對象中 myCache.put("name", "Ben")
3. myCache.get() 返回對應的緩存值,若沒有找到則返回undefined myCache.get("name")
4. myCache.remove() 把鍵值對從對應緩存對象中移除 myCache.remove("name")
5. myCache.remvoeAll() 清空該緩存對象
$http中的緩存
$http()方法允許我們傳遞一個cache參數。當數據不會經常改變的時候,默認的$http緩存會特別有用。其中,默認的$http緩存對象是 var cache = $cacheFactory('$http'); 可以這樣設置它
$http({ method: 'GET', url: 'api/user.json', cache: true })
其中,緩存的鍵值為url, var userCache = cache.get('api/user.json')
自定義緩存
通過自定義的緩存來讓$http發(fā)起請求也很簡單,只需把cache值設為對應緩存對象名稱即可
$http({ method: 'GET', url: 'api/user.json', cache: myCache })
或者通過config配置來設置每個$http請求的緩存對象,而不必像上面的例子中,往每一個$http請求中加入配置
app.config(function($httpProvider){ $httpProvider.defaults.cache = $cacheFactory('myCache',{capacity: 20})
其中,capacity會使用"近期緩存最久未使用算法",就是說,加如緩存容量為20,現(xiàn)在已經緩存了緩存20個,當第21個想要被緩存的時候,最久最小未被使用的緩存鍵值對會被清除,以便騰出空間容納第21個緩存。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Angular.js中ng-if、ng-show和ng-hide的區(qū)別介紹
angularJS中的ng-show、ng-hide、ng-if指令都可以用來控制dom元素的顯示或隱藏。那么這篇文章就給大家主要介紹了Angular.js中ng-if、ng-show和ng-hide的區(qū)別,需要的朋友可以參考借鑒,下面來一起看看吧。2017-01-01Angular動畫實現(xiàn)的2種方式以及添加購物車動畫實例代碼
這篇文章主要給大家介紹了關于Angular動畫的2種方式以及添加購物車動畫的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-08-08angularjs select 賦值 ng-options配置方法
下面小編就為大家分享一篇angularjs select 賦值 ng-options配置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02探索angularjs+requirejs全面實現(xiàn)按需加載的套路
這篇文章主要探索了angularjs+requirejs全面實現(xiàn)按需加載的套路,圍繞angularjs提供的各種機制進行研究,感興趣的小伙伴們可以參考一下2016-02-02