現代的瀏覽器已提供了許多客戶端儲存方式。例如早期的cookie或HTML5後的web storage。然而這兩者都無法儲存大量資料。因此這就造成另一個客戶端儲存方式 – IndexedDB脫穎而出。IndexedDB就像非關聯式資料庫(NoSql),每一個app就有一個專屬的資料庫,裡面包含一些表。因此IndexedDB可儲存非結構化資料。它可以是非同步的,而每個存儲動作就像是關聯資料庫裡的transaction(交易)。只要在存儲中有任何一動作失敗,則整筆交易就會失敗。本篇會先介紹IndexedDB的生命週期和資料的CRUD,接者會介紹較進階的項目如Index, Cursor和Range。
IndexedDB的life cycle
data:image/s3,"s3://crabby-images/9bb68/9bb689c90ef6f3b77a6bf03e66bcc2fec3d1e185" alt=""
由上圖我們知道首先網頁請求(Request)發生,接者瀏覽端IndexedDB程式碼將開始執行。首先判斷是否有新的版本,若有則執行IndexedDB升級動作,例如修改該表的schema或新增資料。若執行成功則繼續執行,若失敗則整個transaction(交易)停止和執行該request onerror這部分的程式碼。
IndexedDB的Initialization 和CRUD
data:image/s3,"s3://crabby-images/cb1a2/cb1a22c00b6bc96b3d9eefee573c18893a29f3a8" alt=""
首先
data:image/s3,"s3://crabby-images/0661d/0661d58eebeb18ca4dca2645732c3859b955aa74" alt=""
這行會啟動indexedDB,此app的資料庫叫testDB,版本為1。
data:image/s3,"s3://crabby-images/7e868/7e868ad900eb4267b249c347692d73107fca167e" alt=""
接者會執行上圖upgrade部分(只有第一次開,版本一初始化時)。上圖會建一個表(名叫users)。上圖在upgrade時,會新增兩筆資料。
data:image/s3,"s3://crabby-images/2053a/2053a2f8afa698b48a996cbe926ef7882cd7a815" alt=""
若該request執行成功則會執行圖上動作。
data:image/s3,"s3://crabby-images/60a08/60a0830fdc1980b7715ec1f8dc918f99c9e507db" alt=""
首先會先取users表,且模式為readwrite。也可以是readonly。
data:image/s3,"s3://crabby-images/aa724/aa724b864df74d9f00a4324ed6c39ba29659c7de" alt=""
上圖也是讀取users表的資料
data:image/s3,"s3://crabby-images/43a0e/43a0e516c049863f4cc97eeba2bf1366620659cd" alt=""
若讀取primary key為1的資料成功,則顯示該資料的name欄位
data:image/s3,"s3://crabby-images/8e4d8/8e4d8f078411fdd3e68bff0b4bd2b4ac09b3b1fb" alt=""
data:image/s3,"s3://crabby-images/39f70/39f70492cb9ea5d224ff6d5a3abbc341a486fc50" alt=""
桉F12到Application這邊,則可以看到該視窗的IndexDB資訊
data:image/s3,"s3://crabby-images/73ab9/73ab96e378b34f1bdaf7517881bd544460c73026" alt=""
新增
data:image/s3,"s3://crabby-images/f4483/f4483a43471f8d54c536ac8227837003909b4993" alt=""
data:image/s3,"s3://crabby-images/84184/84184162cee834223132dfed99346f5096ac76d8" alt=""
讀取
data:image/s3,"s3://crabby-images/5a4f0/5a4f04285db6a4c475d8b5f6e05e33a7b23864bf" alt=""
修改
data:image/s3,"s3://crabby-images/d6cb8/d6cb82dbb5907fdb8bcc8690164a57a54b35ce7d" alt=""
data:image/s3,"s3://crabby-images/fefde/fefdef1101c3cd5619e03197e41257b8b2b991f7" alt=""
刪除
data:image/s3,"s3://crabby-images/a3ae9/a3ae9b2e572c66bd297554507ef8b87e02003b86" alt=""
data:image/s3,"s3://crabby-images/455ac/455acb11c86bcf4efdd41eca7b59780b92bea882" alt=""
Index,Cursor和Range
Index
data:image/s3,"s3://crabby-images/54383/543830e5941da9cbb9033be1356365a3ae898693" alt=""
data:image/s3,"s3://crabby-images/fe40f/fe40fd8eea3f222b2ce84ccd7ea09d2deed4b93a" alt=""
上圖宣告index後,我們就可以用age欄位來查詢數據
Cursor和Range
data:image/s3,"s3://crabby-images/90652/906523082a5ac7dd814bc9fdfe70ad5d461cb1cc" alt=""
先初始化Cursor
data:image/s3,"s3://crabby-images/8ff0d/8ff0d6aaff846696931c0b4cb712ea0263151af4" alt=""
記的最後一定要加上這個code
data:image/s3,"s3://crabby-images/00ee7/00ee761f5ffac83526b84e5367cdb9e392da6a28" alt=""
這樣才會跑完所有資料。
data:image/s3,"s3://crabby-images/21904/21904771aba8cd0032bc6d82cb9b5b7d2cb0ad2d" alt=""
Range
Range要先初始化cursor才能獲得資料
data:image/s3,"s3://crabby-images/92299/922991c5e4b2175a6c401bb72b485ae710cbac47" alt=""
lowerBound(35,false)
該行意思為大於或等於35。第一參數為age,第二為是否包含35。True為不包含,False為包含
data:image/s3,"s3://crabby-images/b5f71/b5f71cc33f5721d9430e4ded6bef2fa412690107" alt=""
data:image/s3,"s3://crabby-images/cc508/cc508f4ef3187f8cbd635c8c8fcf837a08cfbda5" alt=""
小於或等於35
data:image/s3,"s3://crabby-images/8d495/8d4958156966a77f21fac37cbff84c6d79e37d4a" alt=""
data:image/s3,"s3://crabby-images/99bc7/99bc7edbc439c0f008ee822668394d094c2bd830" alt=""
25到30歲之間,包含25和30歲
data:image/s3,"s3://crabby-images/5100e/5100e782168464c34dfb95ff42c9f1aa3db96a42" alt=""
只等於35歲
data:image/s3,"s3://crabby-images/8c1f6/8c1f6792409a5f85e0b626413e6882c749cd07c6" alt=""
本篇介紹了IndexedDB的生命週期,如何增刪改查和說明一些較進階的api操作如Index, Cursor和Range。IndexedDB提供了豐富的API操作,尤其在網路離線時搭配IndexedDB可增加用戶體驗。適當的使用IndexedDB不只在網路端,在移動端也可以協助增加用戶體驗。