[ngrx][ngrxForm]Boxed 類別model 設計應用
如果我們想定義新增畫面的model
waferId這個欄位正常紀錄上就會使用 string[] 型別
data:image/s3,"s3://crabby-images/ff719/ff719a6f5194bb14e85d705ff4a7861e86fb710e" alt="image.png"
但當這樣設計的時候會發現在前端ngrxForm綁定 ngrxFormControlState 時會有錯誤
data:image/s3,"s3://crabby-images/868d2/868d2afe61152a8a07d1cce91b6d4f4248b11a40" alt="image.png"
data:image/s3,"s3://crabby-images/2fba2/2fba2bc7afbecf88cf5d8cefdf7508ec502ffe89" alt="image.png"
這邊官方有給出一個解決方式 [Boxed](https://ngrx-forms.readthedocs.io/en/master/user-guide/value-boxing/)
data:image/s3,"s3://crabby-images/0eca3/0eca3ff13c93ee3fd5ca713f572f9c68bd929f61" alt="image.png"
data:image/s3,"s3://crabby-images/821a9/821a90c016c8be2db51c058e7d81c5f8515611ed" alt="image.png"
設計成Boxed時ngrx在reducer建立出state時就會以 FormControlState的方式做紀錄
而不會是FormArrayState (FormArrayState 我們常用於畫面多層巢狀物件關聯時)
reducer的初始化值也直接assign box方法就可以
data:image/s3,"s3://crabby-images/a5a83/a5a836e5a02357a506fd3ab53f6c56100ca6aa7a" alt="image.png"
-----
有時候一個form中的formControl 會有存在多個單一值,但僅能當作一個值的情況
例如
data:image/s3,"s3://crabby-images/e8966/e8966493331bd1331a7bc1df0f268278123a5069" alt="image.png"
data:image/s3,"s3://crabby-images/6a21a/6a21a959c481d7bcab4c8b18a96ed75ab5c7b99b" alt="image.png"
這種formControl 我們在model設計就會加上
data:image/s3,"s3://crabby-images/6ad95/6ad9568a724da600e5cf71f053a2c3f9da91db7e" alt="image.png"
取用陣列時直接取用
data:image/s3,"s3://crabby-images/d709c/d709cfb4661d1e6edefd763dc6a53920004940d0" alt="image.png"