I have a XML file stored in the database as XML format which contains some controls like drop down text box, label text area, etc. which may or may not have initial values. So my aim is to read the XML file and based on the control type, I need to create that control dynamically and associate the initial value if any and the preview of the page have to be shown in a view. Anybody please help me how to create the controls dynamically in MVC 3 for this scenario.
For eg: my xml file will look something like this.
<?xml version="1.0" encoding="utf-8" ?>
<controls>
<control>
<type name="label">
<property name="Visible" value="true"/>
<property name="ID" value="Label1"/>
.
.
.
</type>
</control>
<control>
<type name="TextBox">
<property name="Visible" value="true"/>
<property name="ID" value="TextBox1"/>
.
.
.
</type>
</control>
.
.
.
</controls>
Thanks in advance.
I will try to provide you with some hints that might give you some ideas.
As always let's start by defining a view model which will represent the UI:
So we have defined some of the basic controls we would like to handle in our application. The next step would be to have a repository method which will query the database, fetch the XML and then a mapping layer that will finally provide us with an instance of our view model. I am leaving this as out of scope for this answer as there are many ways you could implement it (XmlSerializer, XDocument, XmlReader, ...).
I suppose that you already have an instance of the view model. Like this:
So I have hardcoded some values in order to illustrate the concept, but normally this controller action would look something like this once you implement the repository and mapping layer:
OK, now let's move to the corresponding
Index.cshtml
view which will contain the form:OK, so now we can define the corresponding editor templates for the controls we would like to handle:
~/Views/Shared/EditorTemplates/TextBoxViewModel.cshtml
~/Views/Shared/EditorTemplates/CheckBoxViewModel.cshtml
~/Views/Shared/EditorTemplates/DropDownListViewModel.cshtml
So far, so good. At this stage you should be able to render a form containing the dynamic controls. But of course such a form is pretty useless to anyone. What would be nice is to have the possibility of POSTing this form and capturing the values entered by the user in a controller action so that we could process them.
The controller action would look like this:
Now that would be nice but of course it won't work because the
ControlViewModel
view model is an abstract class and the default model binder has no clue about which specific implementation to instantiate. So we need to help him => by writing a custom model binder:which will be registered in
Application_Start
and associated to theControlViewModel
type):It seems to be quite simple in fact. Get your XML from the database, parse it and put it into some model classes. Those classed will contains controls data.
Next create partial view which will dynamicly build required controls depending on model.
At the end, call that action from jQuery ajax and put returned HTML in the proper place.
Quick, easy, no reaload....
you can pass a model to your strongly typed view andwrite a html helper named Html.ControlFor in the helper you can read the xml file and create controls (input, select etc.) based on match of property name (where property name matches property tag in xml file)