2011-11-11 69 views
2

這更多的是一個概念性問題。如果有幫助,可以說它屬於MVVM模式。我從未在WPF綁定研究中看到過這一點。通過綁定取消WPF中的更新

如果您有一個窗口,通過綁定連接到視圖模型並且用戶更新記錄,但在保存之前決定取消更新,那麼您認爲顛倒這些更改的最佳方法是什麼?

我能想到幾個可能性:

  1. 而是允許用戶更新主顯示,有第二個窗口彈出的綁定到虛擬機,並在副本編輯「保存「,將數據寫入原始虛擬機,然後更新回模型。 增加了保存功能的內存使用量和複雜性。
  2. 製作原始VM對象的「原始」副本,並在「取消」後,將該VM寫回原始(此時可以刪除副本)。 增加取消功能的內存使用量和複雜度。
  3. 創建VM中每個元素的副本,這些元素在創建時可能會發生更改,並且在「取消」時將這些值寫回到更改的元素上。 增加VM的大小和複雜性。
  4. 執行「取消」後,虛擬機命中數據源並重新加載記錄。 導致網絡流量和數據庫訪問流量,並可能延遲顯示更新回原始狀態。如果虛擬機已從另一個進程更新並且不應刪除這些「外部」更新,也可能會導致問題。

任何人都可以想到更好的解決方案,或知道WPF中的一些模糊的功能來處理這個「自動」?

回答

2

我已經在ViewModels上實現了IEditableObject,並通過調用EditCommand進入編輯模式時創建了字段的副本。

我還有確認編輯時可以調用的SaveCommands。或者使用CancelEdit命令恢復到複製的值。

+0

我使用一個紀念碑的實現,它使用反射來自動保存/恢復標記有特定屬性的字段 - 很好,很簡單 –

+0

我生成我的ViewModels,所以我不必編寫無聊的複製代碼,不要忍受反射遲緩 –

+0

反射的最慢部分是獲取屬性定義,您可以按類型緩存,因此它的命中率也不算太差。不過,自動生成也是一個不錯的選擇 –

0

關鍵是模型應該能夠回滾用戶的變化。你怎麼做這真的是一個品味問題。您可以通過使用「原始」副本(並非所有對象都很容易克隆)來回到未改變的狀態,您可以重新查詢數據庫,在這種情況下,您是否有機會得到與您最初嘗試的內容不同的內容編輯。這個問題沒有通用的解決方案。

3

我認爲最簡單的方法是使用BindingGroup,它會延遲更新VM,直到用戶顯式提交更改。這樣,控件將緩存更改的值,並且BindingGroup將能夠從(仍然不變的)VM中恢復原始值。

+0

是的。這種方法沒有上面列出的缺點。不幸的是,它可能會引入對象驗證的問題,因爲在Model內執行復雜的驗證更好,或者至少ViewModel – Lu55

+0

好吧,如果ViewModel可以暴露ICommand實現,爲什麼它不應該公開ValidationRules?例如,您可以在ViewModel上將ValidationRules實現爲靜態成員。特別是對於BindingGroup上的ValidationRules,您甚至可以通過這種方式訪問​​ViewModel實例及其私有成員。 – hbarck