現今電腦使用者處理資料大都是透過呼叫Http服務到伺服器執行相關的處理,但有時候你只想測試並不想真的要執行Http服務到遠端伺服器通訊工作。在Angular裡,它提供了一個套件可供使用者模擬終端伺服器通訊。該套件為記憶體Web Api(In-Memory Web Api)。安裝該套件後,Http服務會被該記憶體Web Api攔截和模擬響應。
要安裝該套件需要DOS到專案的目錄執行npm指令
data:image/s3,"s3://crabby-images/21f55/21f55d7820eb2a609bd2f2d8f9ee48974339646d" alt=""
執行完後需要在AppModule中匯入HttpClientModule和InMemoryWebApiModule模組
data:image/s3,"s3://crabby-images/456d1/456d1f8138c476d5cb97bf6c6c8fd951e4282e12" alt=""
接者用forRoot()接受一個InMemoryDataService來初始化記憶體資料庫
data:image/s3,"s3://crabby-images/244cb/244cb213bb32a56e4e5dd9aaeb8eb7eb528f4fc9" alt=""
以下為AppData ts檔,該class需要implements InMemoryDbService和建立createDb方法
data:image/s3,"s3://crabby-images/05645/05645d2c10167317e189499c2095af41d388d6bc" alt=""
Product類別
data:image/s3,"s3://crabby-images/2bb39/2bb392ecf64e5adcdf45f07f8ac525ea2e30ba9b" alt=""
記得把AppData也加入到AppModule裡
data:image/s3,"s3://crabby-images/e7d6c/e7d6c472ce5db027e14876291521797fd2f48108" alt=""
透過rxjs執行 http get服務得到產品(Product)資訊
data:image/s3,"s3://crabby-images/17ea6/17ea6380fb9fd6cda4e50c5c80250d531d1a38a5" alt=""
Html頁面
data:image/s3,"s3://crabby-images/f7660/f76602c30a3e4ab99df74db8b2220f31ec97f987" alt=""
已上顯示如何用該套件(In-Memory Web Api)模擬資料的查詢。除了查詢,新增,刪除和更新也可用該套件模擬達成。