DRY vs Security and Maintainability with MVC and View Models

前端 未结 2 1258
长发绾君心
长发绾君心 2021-02-09 20:32

I like to strive for DRY, and obviously it\'s not always possible. However, I have to scratch my head over a concept that seems pretty common in MVC, that of the \"View Model\"

相关标签:
2条回答
  • 2021-02-09 20:43

    One could also note that not using view models would be a violation of the single responsibility principle -- your entity should not be polluted with UI concerns.

    I also think the real value of view models doesn't necessarily become apparent in version 1.0 of your application. You will thank yourself when working on version 2.0 when you completely re-think how your back-end works but you don't have to carry those changes out to the view layer.

    0 讨论(0)
  • 2021-02-09 20:47

    This has been brought up time and time again. Not only is it a pretty substantial dupe but the answer is subjective and argumentative. ViewModels are a response to DDD and the concept of persistence ignorance.

    To say not using ViewModels is bad means ignoring that Django and Rails and most PHP ORM/MVC frameworks don't care at all about those concepts. Do you want somebody to tell you all those other languages and frameworks are "doing it wrong?".

    Whether or not you want to use ViewModels is 100% dependent on what architecture styles you are going for and what the goals of the application are.

    This is like asking is dragging and dropping GridViews in a WebForm app appropriate? Depends on a lot of things.

    There is also a misconception about DRY that you have here. Do Proxy classes from a WCF service violate DRY? Does the ViewModel contain logic? The primary goal of DRY is to not have duplicated logic with a meaningful purpose. Do a couple of DTOs that share object shapres violate that?

    The DDD principal of bounded contexts would make for a good read too. If a ShoppingCart object needs to function differently in a warehouse vs ecommerce website setting does that mean you to share the types? What happens when the only shared functionality is totaling a price ( price + tax + shipping )? Do you create a base class just for that therefore increasing coupling? What are the tradeoffs in time/cost/maintenance for being 100% DRY for a simple method like GetTotal(). Does violating DRY when it makes sense actually decreasing the complexity and overall cost of maintaining your codebase?

    I'm sorry for answering with so many questions but hopefully now you can see the nuances and intricacies of the question you asked. ;)

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