怎麼理解圖中的話,最好有demo
自己寫了個demo超過了限制的capacity:3但是每次快取cache.info()列印出來的size都一樣。另外$cacheFactory(key,[option])中的key只能是一個字串嗎,如何一次定義多個快取物件
capacity相當於給該cache規定了一個可以使用的最大容量。 舉個簡單例子,假如你有3個水桶(capacity=3),你裝了第一桶水(put),那麼它還是有3個桶。再裝一桶水,直到裝到第四桶水的時候,因為只有3個桶,顯然這桶水裝不下了,怎麼辦呢?把最先裝的那桶水倒掉,用這個桶來裝第四桶水(cache策略:LRU)可以看一下$cacheFatory的實現,應該會有更深的理解
capacity 涉及到的是LRU(Least Recenlty Used, 最近最少使用)緩存,如:
var lru = $cacheFactory('lru', {capacity: 20}); // $http请求 $http.get('/api/users.json', {cache: lru}).then(function(data){});
現在,最新的20個請求會被快取。第21個請求會導致LRU從快取中將時間比較舊的請求移除掉。
我們也可以透過應用的.config()函數,也就是配置階段為所有$http請求設定一個預設的快取:
angular.module('myApp', []) .config(function($httpProvider, $cacheFactory) { $httpProvider.defaults.cache = $cacheFactory('lru', { capacity: 20 }); });
capacity相當於給該cache規定了一個可以使用的最大容量。
舉個簡單例子,假如你有3個水桶(capacity=3),你裝了第一桶水(put),那麼它還是有3個桶。再裝一桶水,直到裝到第四桶水的時候,因為只有3個桶,顯然這桶水裝不下了,怎麼辦呢?把最先裝的那桶水倒掉,用這個桶來裝第四桶水(cache策略:LRU)
可以看一下$cacheFatory的實現,應該會有更深的理解
capacity 涉及到的是LRU(Least Recenlty Used, 最近最少使用)緩存,如:
現在,最新的20個請求會被快取。第21個請求會導致LRU從快取中將時間比較舊的請求移除掉。
我們也可以透過應用的.config()函數,也就是配置階段為所有$http請求設定一個預設的快取: