Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

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.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 342035
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 12, 20262026-05-12T10:45:54+00:00 2026-05-12T10:45:54+00:00

We’re just getting into MVVM in WPF. We have implemented our ViewModels with ‘strongly

  • 0

We’re just getting into MVVM in WPF.

We have implemented our ViewModels with ‘strongly typed’ properties (int, double? etc.) that we bind to in the view.

Type conversion works OK, mostly, and so entering data is simple enough. But we run into problems with validation.

If, say, a non-numeric value is entered in a text box bound to a numeric property, the conversion fails, the property is never set, and we never get a chance to provide proper feedback to the user. Worse, the property retains its current value, leading to a mismatch between what’s displayed in the view and what’s actually in the ViewModel.

All this can be handled with value converters, I know. But I have seen several opinions to the effect that conversion should not be the view’s responsibility at all. What is entered in the view are strings, and the conversion, validation etc. should be the ViewModel’s responsibility (so the argument goes).

If so, we should rewrite most of the properties on our ViewModels to string, and provide error information through the IErrorInfo interface, for example. It would surely make for simpler, leaner XAML in the view. On the other hand, conversion, validation etc. will be less declarative, explicit and flexible, from the point of view of the View designer.

It seems to us these two approaches are fundamentally different, so before we decide, we’d like some informed SO opinions on the matter.

So: should ViewModels expose a simplified, ‘text-based’ interface to the view and handle conversion internally? Or should ViewModel properties expose the actual data types, leaving such chores to the view to handle?

Update:

Hard to pick a winner here, but I finally landed on one of you who concludes more or less like myself.

Specifically, we have decided to keep the ViewModel properties typed. The main reason for this is the flexibility it affords us in the design of the view, and the power of explicit, declarative conversion/formatting in XAML.

I noticed an assumption with you who will disagree with us in this, that the design of the view is fixed and ready. Hence, no decisions about conversion, formatting etc. need be made in the view. But ours is an agile process, and we haven’t got all the nitty gritty detail of the UI figured out on beforehand.

In fact, leaving the details of the UI to be worked out along the way leaves room for creativity and besides, in my opinion, even a meticulously worked out design will always end up morphing throughout the implementation process.

The point of all this is that whereas business rules enforcement certainly belongs in the ViewModel, it seems to us that simple conversion and formatting is a view-thing. It may sound like heresy, but I don’t actually think type conversion in the view needs unit testing at all (so long av we unit test the actual type converters).

All in all a great discussion, folks, with well formulated, informed opinions. Thanks.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-12T10:45:54+00:00Added an answer on May 12, 2026 at 10:45 am

    This is a very interesting question and one that I don’t feel has a definitive answer, but I’ll do my best to throw my thoughts out there.

    Looking at the MVVM pattern as I understand it, the point of the ViewModel is to expose the data in a way the View can understand without any assumptions about the way the view is going to use it. For an example let’s pretend that we are modelling the speed of a car:

    public class CarModel
    {
        public int MilesPerHour { get; set; }
    }
    
    public class CarViewModel
    {
        private CarModel _model;
    
        public int MilesPerHour
        {
            get { return _model.MilesPerHour; }
            set { _model.MilesPerHour = value; }
        }
    }
    

    In the example above I’ve exposed the property as an int since that is what it is in the model. The disadvantages of this you have listed in your question, but the main advantage is that it gives the creator of the view a valuable piece of information about how to display that data. Remember that we (as the authors of the ViewModel) don’t know what the View looks like. By committing to the idea of the data being an int the View can use a textbox or some other control that only accepts numbers (a dial, for example) to display the information. If we say that we are going to format the data in a way that we assume is helpful to the View it takes that important power away from it.

    On the other hand we work in real world. We tend to know what the view is. We rarely plug and play different views on top of the same ViewModel and adding the conversion code into the ViewModel is simply easier. I don’t think it is right, but that doesn’t mean you won’t find my production code using it…

    Finally (and I’m sure you know this, but for completions sake…) business logic should be done in the ViewModel. If we decide that the car shouldn’t go above 70mph then it isn’t the responsibility of the view to enforce that. So you’ll still end up with some kind of error provider, but at a business rather than display level.


    Okay, maybe that wasn’t finally….

    I wanted to address the comments made by Kent, and my thoughts didn’t fit into a comment.

    Obviously the primary difference between my and Kent’s point of view (as I understand it) is he reads ViewModel to be a Model of the View and I read it to be the thing that exposes the Model to the View. A subtle difference I’ll admit, but I think the upshot is that I don’t want to remove information that the model provides, even if it makes it easier for the specific view I’m using.

    My point of view is based on the assumption that you should be able to swap views out, they should be fleeting things that may change depending on the requirements of screen size, hardware, platform, latency and environment. The interesting twist is that I have never actually needed this functionality, nor seen anything (beyond proof of concept applications) that have ever used it, but if we accept that we won’t use it now or at any point in the future, and that each ViewModel will work with one, and only one, View then we may as well go back to putting all the code in the code-behind file and throw the ViewModel out completely – after all, it’s so tightly coupled that it may as well be the same class.

    Ideally I would like a situation where the ViewModel can say “this value is an int, it will always be an int, and you can display it in anyway that you like. But you can give anything back to me and I’ll do my best to make it fit, and if I can’t I’ll let you know”. Basically my MilesPerHour property should have an int getter, but an object setter. That way the views keep all the information I feel they need, but don’t have to worry about conversions or validation.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 254k
  • Answers 254k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer If, as you pointed out in the comments, your /src/java… May 13, 2026 at 10:11 am
  • Editorial Team
    Editorial Team added an answer You basically have two options in Word 2007 to add… May 13, 2026 at 10:11 am
  • Editorial Team
    Editorial Team added an answer You're going to want to change your user-agent; here's an… May 13, 2026 at 10:11 am

Related Questions

We are developing a little application that given a directory with PDF files creates
We have been using CruiseControl for quite a while with NUnit and NAnt. For
We have a requirement in project to store all the revisions(Change History) for the
We have a remoting singleton server running in a separate windows service (let's call
We have an SVN repository running on a Windows server, and I want to

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.