MVVM's Place in Your App
Picking up on my post “MVVM Is Quite Okay at What It Is Supposed to Do”, here’s a few images which illustrate the problem of mistaking MVVM for a solution to a structural problem. It’s the whole post in 2 images.
Model–View–View-Model helps with the view layer. It can be a tool to break up a view controller into smaller things. But it’s still only a refactoring of view components into more objects.
data:image/s3,"s3://crabby-images/59cd0/59cd0108eb65fed92f993083e266e8f49cbcbd89" alt="diagram of MVVM in the view layer"
That’s useful and not a problem itself. But it doesn’t help if your overall app is a mess.
The technical term for “mess” on the level of software architecture is “Big Ball of Mud”; combine MVVM and BBoM and you have … MVVM in a BBoM.
data:image/s3,"s3://crabby-images/f993b/f993b956c1527c5ef3b5c73c4227ba5182bd6f29" alt="diagram of MVVM components in a chaos"
There you see that MVVM can affect the picture of your architecture – but not by much. It’s a design pattern you can use to solve a particular coding problem, but it can’t bring order (or structure) to the chaos.