I have been reading Scott Guthrie's and Scott Hanselman's posts on ASP.NET MVC and it got me thinking. Here are a few points that I think would be interesting to discuss further:
-
Quite soon after I started developing Business Web Applications, circa 2001, I came to the conclusion that the programming model offered at the time did not suite a Business Application so well. HTML, then ASP, and finally ASP.NET, had serious shortcomings as far as developing Business Applications. This is not to say that it was not possible to develop them.
The programming model that came to my mind was as follows:-
UI happens in HTML in the Browser (no back and forth postbacks for updating the UI).
-
Navigation happens in the Browser (no need to go to the server to navigate to a new page).
-
You only go to the server for Business Processing and Data. (Well, this is kind of like AJAX)
Wait a second; now that I think of it, this model reminds me of something! Hmmm...
This looks a lot like Smart Client Application, or Silverlight, but developed in HTML. Wow, what do you know, the programming models for Business Applications are merging ...
Of course, none of the tools of the time supported the model I had in mind very well.
In my opinion, ASP.NET MVC takes a huge step in the right direction. However, it is not quite there yet.
For instance, regarding Navigation, when you initiate a POST or a GET from the browser, it is the decision of the browser where to put the returning HTML. This does not seem to sit so well with the notion that the ASP.NET MVC Controller decides which View to render on the server.
Furthermore, if your navigation is done from the server by Rendering a new View, does this mean that we will go back to whole pages refreshing every time you go to the server? I thought we were on the verge of resolving this problem with AJAX. -
- ASP.NET MVC is NOT ASP.NET! In all the blog posts and presentations I saw coming out from Microsoft about ASP.NET MVC they make a point to say that it is an extension on top of ASP.NET and that the two models will play well together. I think that in reality, this is not the case. If the ASP.NET MVC programming model catches on, it will completely deprecate ASP.NET. ASP.NET is about the controls and their event handling model. But the ASP.NET controls are a no no in ASP.NET MVC because no Post Back is allowed (or supported). This is just the same as the fact that you can still use ASP style programming in your ASP.NET pages, however, no one in their right mind does.
- ASP.NET MVC does a great job in regard to "Separation Of Concerns". However, when I originally learned about the MVC Pattern it was suggested that an implementation would allow sharing the business part of the application between Web and WinForms based UI implementations of the same application. I am not sure ASP.NET MVC is suitable for this (or was intended to do this). So, this brings up a couple of questions:
- Is it possible to share the business part of the application between a WinForms implementation and a Web implementation of the UI? How much customization would that require?
- How much further does the model need to be changed to support this inherently?
In summary, I would like to say that these are just my thoughts. I hope that they will contribute to a fruitful discussion and to a better implementation.