How to build the ViewModel in MVVM not to violate the Single Responsibility Principle?

后端 未结 4 1028
花落未央
花落未央 2021-01-17 12:15

Robert Martin says: \"There should never be more than one reason for a class to change\".

Let\'s consider the ViewModel class which is bound to a View. It is

相关标签:
4条回答
  • 2021-01-17 12:36

    I agree that splitting your screens into multiple Views with multiple ViewModels is necessary to reduce bloat and complexity. Here's another pattern I've employed to help stick to SRP using MVVM:

    Here's one scenario. My ViewModel needs to obtain data and respond to filter commands from the UI. I create the ViewModel to be composite in structure. That is, child classes that have access to private members of the ViewModel perform linear tasks such as handling the filtering. I might also have another child class that performs the necessary logic for selection of items based on criteria. You get the idea. Once the ViewModel is performing certain functions that span across several methods, it may be a good candidate to delegate to a child class. The child classes remain part of the main ViewModel, so it's just a way of reducing the size of the ViewModel and makes unit testing these linear operations easier.

    0 讨论(0)
  • 2021-01-17 12:45

    Yes, but that doesn't mean poor design couldn't force you into it.

    0 讨论(0)
  • 2021-01-17 12:49

    I agree with gcores.

    Once you see ViewModel grow to more than two screenfuls of text, it is time to consider splitting ViewModel into several child models.

    Another rule of thumb is that I never have more than two levels of nesting inside XAML file -- if one part of the view becomes too complex, it is time for view refactoring -- extract inner XAML into separate UserControl and create corresponding ViewModel, which will be default data context on child view.

    0 讨论(0)
  • 2021-01-17 12:55

    The ViewModel single responsibility is to provide the View the information it needs. If the View needs different and unrelated properties that is not important as the ViewModel only has one reason to change and that is the View showing different properties. So you shouldn't worry too much.

    That said, if the ViewModel does get huge, maybe you could think about dividing the view into several subviews to improve reusability and keep the Views and the ViewModels manageable.

    0 讨论(0)
提交回复
热议问题