Defining Structure in Code-Behind
The following article demonstrates how to define the structure of the RadPageLayout from code-behind.
You can define the structure of RadPageLayout and add the content dynamically in server-side code. In order to achieve this, you should create an instance of the control along with the desired structure (Rows, Columns and Content) and add it to the page.
Example
The example below demonstrates how to create the RadPageLayout object, along with the needed content holders.
Figure 1 demonstrates the layout of the example.
protected void Page_Load(object sender, EventArgs e)
{
RadPageLayout pageLayout = new RadPageLayout();
pageLayout.GridType = GridType.Fluid;
pageLayout.CssClass = "borderCssClass";
LayoutRow row = new LayoutRow();
LayoutColumn layoutColumn = new LayoutColumn();
Label label1 = new Label();
label1.Text = "Main Content Here";
layoutColumn.Span = 8;
layoutColumn.Controls.Add(label1);
row.Columns.Add(layoutColumn);
CompositeLayoutColumn compositeColumn = new CompositeLayoutColumn();
compositeColumn.Span = 4;
LayoutRow row1 = new LayoutRow();
Label label2 = new Label();
label2.Text = "additional content 1";
row1.Content.Controls.Add(label2);
LayoutRow row2 = new LayoutRow();
Label label3 = new Label();
label3.Text = "additional content 2";
row2.Content.Controls.Add(label3);
compositeColumn.Rows.Add(row1);
compositeColumn.Rows.Add(row2);
row.Columns.Add(compositeColumn);
pageLayout.Rows.Add(row);
form1.Controls.Add(pageLayout);
}
Protected Sub Page_Load(sender As Object, e As EventArgs) Handles Me.Load
Dim pageLayout As New RadPageLayout()
pageLayout.GridType = GridType.Fluid
pageLayout.CssClass = "borderCssClass"
Dim row As New LayoutRow()
Dim layoutColumn As New LayoutColumn()
Dim label1 As New Label()
label1.Text = "Main Content Here"
layoutColumn.Span = 8
layoutColumn.Controls.Add(label1)
row.Columns.Add(layoutColumn)
Dim compositeColumn As New CompositeLayoutColumn()
compositeColumn.Span = 4
Dim row1 As New LayoutRow()
Dim label2 As New Label()
label2.Text = "additional content 1"
row1.Content.Controls.Add(label2)
Dim row2 As New LayoutRow()
Dim label3 As New Label()
label3.Text = "additional content 2"
row2.Content.Controls.Add(label3)
compositeColumn.Rows.Add(row1)
compositeColumn.Rows.Add(row2)
row.Columns.Add(compositeColumn)
pageLayout.Rows.Add(row)
form1.Controls.Add(pageLayout)
End Sub
<head runat="server">
<title></title>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<style type="text/css">
.borderCssClass div {
border: 1px solid red;
}
</style>
</head>