MonoRail and Update Panel
It seems like a MonoRail implementation of the UpdatePanel is fairly high for people coming to MonoRail from the WebForms world. I am doing a project that uses Update Panel fairly extensively, and I can see why, it is really nice way to add Ajax capabilities to your web form. I started to look into what it would take to implement it with MonoRail, and I came to two conclusions:
- The technical challanges on the server side are minor, on the client side it is more of an issue, but not hugely so.
- The default architecture for UI in MonoRail basically makes it a non applicable.
I guess that I should explain.
The Web Form architecture is constraining the page to mostly interact with the page using post backs. There is a whole mechanism at both client and server side that is used to make this happen, which is what the Update Panel plugs into. This means that programming concepts such as AutoPostBack=true are very common on the WebForms world, and a great deal of work is done on the same page.
MonoRail, on the other hand, doesn't place such constraints, and the default architecture for the UI is radically different. Instead of interacting mostly with the same page, mostly using postbacks, you tend to have a more relaxed model, where you usually talk to the controller, and that chooses one of several views to send your way.
When I say "talking to the controller", I mean issuing requests to the application, most often, Ajax seems to be the choice for that, but moving between actions and views using POST/GET is fairly common as well. While you could build the views to work in the same manner as Web Forms, I have hard time thinkning about good reasons why you would want to do that.
So, I hope we can agree that the default architecture between the two is hugely different. Now, let us go back to the update panel request. While the mechanics may not be the same, it is fairly common to want to replace part of your page. And it wouldn't be nice if MonoRail made it hard. Well, as it turn out, it doesn't.
In my MonoRail web cast, I have shown how it can be done, you have a piece of the UI that you want to replace using Ajax. Let us take Fowler's refactoring approach:
- You decide that you want to update a part of the UI dynamically.
- You extract that part into a separate view (mostly involving Cut&Paste)
- You call the new view from the old view
- You create a new method on the controller that would rendner the new view and return it.*
- On the UI, you create an Ajax.Updater element that would call the new method on the server (and automatically replace the part of the page with the returned result).
* There are several ways to do it, a new method is one, specifying different view for the same method is another, which I sometimes like more.
Comments
There is an error in the link "MonoRail web cast".
;o)
thanks, fixed.
I'd like your MR template :)
I still have just RC2 install from website as current, which is quite old.
I wish Castle would update the install soon to handle NH1.2 as well as new features and bug fixes.
I know this won't be taken so well, but I'll say it anyway :)
Around the 45 minute mark you're showing the Ajax section in Monorail. There is a quite a bit of plumbing going on in my opinion to pull this all off.
Obviously you have experience with the library, you know the parameters, the steps involved, etc...
After seeing you type in the 'Scriptmanager' in about 30 seconds, I was thinking, that is quite impressive actually when you compare to all the steps for Monorail.
ie. what if there was a ViewComponent - similiar to your SmartGrid, where you tell it what controller.action to invoke to fill that div ? It would make the asynchronous call, the controller would execute and return the string back to the div. That way the controller is still in control. The view is only saying 'here is what view to load into this div'
Just a thought
Steve,
Yes, for the simple scenario, it is easier to use the update panel, and I can build a component that would do the same fairly easily. The issue is that it is rarely this simple. You often need to correlate actions between several user interactions, and that gets to be fairly complex very soon.
The reason that there isn't such a component is that it is not very useful when you move beyond those simple scenarios, and it is better not to abstract things too much.
Bad news - on a new project it was decided against Monorail since no one is an 'expert' on it - and some of the work might be done 'remotely'.
There is a real fear imo about going outside of webforms, although we are using NHibernate.
I was wondering still, how bad is it to go with the MR Webform approach?
Not much is discussed on this approach, although I think it might represent a mid-way point for those leary of making the 'big leap'?
Your thoughts?
Comment preview