angular.js - angularjs $cacheFactory capacity 怎么理解
問題描述
怎么理解圖中的話,最好有demo
自己寫了個(gè)demo超過了限制的capacity:3但是每次緩存cache.info()打印出來的size都一樣。另外$cacheFactory(key,[option])中的key只能是一個(gè)字符串嗎,如何一次定義多個(gè)緩存對象
問題解答
回答1:capacity相當(dāng)于給該cache規(guī)定了一個(gè)可以使用的最大容量。舉個(gè)簡單例子,假如你有3個(gè)水桶(capacity=3),你裝了第一桶水(put),那么它還是有3個(gè)桶。再裝一桶水,直到裝到第四桶水的時(shí)候,因?yàn)橹挥?個(gè)桶,顯然這桶水裝不下了,怎么辦呢?把最先裝的那桶水倒掉,用這個(gè)桶來裝第四桶水(cache策略:LRU)可以看一下$cacheFatory的實(shí)現(xiàn),應(yīng)該會(huì)有更深的理解
回答2:capacity 涉及到的是LRU(Least Recenlty Used, 最近最少使用)緩存,如:
var lru = $cacheFactory(’lru’, {capacity: 20});// $http請求$http.get(’/api/users.json’, {cache: lru}).then(function(data){});
現(xiàn)在,最新的20個(gè)請求會(huì)被緩存。第21個(gè)請求會(huì)導(dǎo)致LRU從緩存中將時(shí)間比較老的請求移除掉。
我們還可以通過應(yīng)用的.config()函數(shù),即配置階段給所有$http請求設(shè)置一個(gè)默認(rèn)的緩存:
angular.module(’myApp’, []).config(function($httpProvider, $cacheFactory) { $httpProvider.defaults.cache = $cacheFactory(’lru’, {capacity: 20 });});
相關(guān)文章:
1. javascript - 你們怎樣實(shí)現(xiàn)前端分頁的?2. javascript - 關(guān)于fullpage.js 自動(dòng)高度失效的問題3. 如何使用git對word文檔進(jìn)行版本控制?4. javascript - 移動(dòng)端粘貼事件,onpaste事件在app中無效,在app中怎么監(jiān)測到粘貼事件5. android - react-native 的headless.js Java API 的代碼怎么使用?6. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?7. python - 在使用Pycharm時(shí)經(jīng)常看到如下的樣式,小括號里紅色的部分是什么意思呢?8. python小白 想做一個(gè)能夠計(jì)算圓周率的代碼,不知道怎么寫9. css - 如何選擇字體?10. javascript - Express 和 request 如何代理遠(yuǎn)程圖片?
