I always find it tempting to put a model and a view-model together in one class, and I don’t see the downside of doing that.
There must be a good reason for separating them. What am I missing?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
The first real downside of doing this is a lack of separation of concerns. And soon this will lead to redundant code. Now, that said, I’ve seen a lot times where developers have used their Model objects as ViewModels. And if we’re totally honest with ourselves, in a very thin app, separating these concepts can actually lead to more redundancy.
The best thing you can do is learn more about MVVM, and its roots in MVC and Presentation Model, but I think it’s a great thing that you’re asking this question and that you’re not blindly following dogma. In fact, I often don’t even start with MVVM at all when I begin a small app. I’ll often start with a hundred lines or so in the code-behind, proving a concept, and then start refactoring it into MVVM.
More to the point of your question, the model and view-model have – in a conceptual sense – very different purposes. The Model includes your business logic (domain logic), data model (objects, attributes and relationships), and data access layer. The ViewModel is essentially an adaptor for the Model, adapting it for the specific purposes of the View. In some cases you might have 3 different views (and view-models) for a given data model object. Each view-model would be adapting those same attributes on the model object for the specific purposes of that particular view.