首頁 >web前端 >js教程 >AngularJS中的快取使用

AngularJS中的快取使用

高洛峰
高洛峰原創
2017-01-13 15:33:101122瀏覽

緩存篇

一個快取就是一個元件,它可以透明地儲存數據,以便以後可以更快地服務於請求。多次重複地取得資源可能會導致資料重複,消耗時間。因此快取適用於變化性不大的一些數據,快取能夠服務的請求越多,整體系統效能就能提升越多。

$cacheFactory與快取物件

$cacheFactory是為Angular服務生產快取物件的服務。要建立一個快取對象,可以使用$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發起請求也很簡單,只需把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,現在已經快取了快取20個,當第21個想要被快取的時候,最久最小未被使用的快取鍵值對會被清除,以便騰出空間容納第21個快取。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持PHP中文網。

更多AngularJS中的快取使用相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn