Skip to main content

ASP.NET Using Master Pages



Master Page: Page with .master extension. Includes a complete web page structure. User <@Master> instead of <@Page> directive. Contains a ContentPlaceHolder.

ContentPage: .aspx file. Defines a ContentPlacHolder. Refers to its Master page in <@Page MasterPageFile = “mainPage.aspx”> directive.






To Attach Master Page at Page Level:


To attach Master Page to all page in web.config.
Only pages with <Content> controls.

One can also specify master page for each folder in web application by providing a different web.config for each folder.


Referencing Master page Properties, Methods and Controls from Content Page:

To do this Refer to the property or control of Master page in content page use<@MasterType> declaration.

<@ MasterType virtualpath = “~/MainTheme.master”>

In case of multiple base pages all master page should inherit from the a single base page. Then use that base Master Page as <@MasterType>.

To reference properties use:

Master.CompanName;


Referencing controls in Master Page:

Label companyName = (Label) Master.FindControl(“lblCompanyName”);

Handling Events when working with Master Pages:
The following is the sequence in which events occur when a master page is merged with a content page:
1.       Master page controls Init event.
2.       Content controls Init event.
3.       Master page Init event.
4.       Content page Init event.
5.       Content page Load event.
6.       Master page Load event.
7.       Content controls Load event.
8.       Content page PreRender event.
9.       Master page PreRender event.
10.     Master page controls PreRender event.
11.     Content controls PreRender event.


Creating Nested Master Pages:
          B master page inherits A master page. So, B’s Page directive will look like:

<@Master language = “C#” master = “A.Master” >
<asp:Content > to Cover A’s ContentPlaceHolder
<!--- Some Extra HTML -->

<asp:ContentPlaceHolder>
</asp:ContentPlaceHolder

</asp:Content>

Dynamically Changing the Master Page:

To dynamically alter the master Page one will have to override Page_PreInit().

Void Page_PreInit(Object sender, EventArgs e)
{        MasterPageFile = “MasterPage2.master”; }

Popular posts from this blog

Culture Information and Localization in .NET

Namespace: System.Globalization CultureInfo Class:                 It provides information like the Format of numbers and dates, Culture’s Calendar, Culture’s language and sublanguage (if applicable), Country and region of the culture. The Basic use of CultureInfo class is shown here: • How string Comparisons are performed • How Number Comparison & Formats are performed • Date Comparison and Formats. • How resources are retrieved and used. Cultures are grouped into three categories: Invariant Culture : It’s Culture Insensitive. It can be used to build some trial application. It can be also used to build an application with hard-coded expiry date that ignores cultures. But using it for every comparison will be incorrect and inappropriate. Neutral Culture : English(en), Frensh(fr), and Spanish(sp). A neutral culture is related to language but it’s not related to specific regi...

Concept of App Domain in .Net

Creating Application Domains: Application domain is just like process, provides separate memory space, and isolates from other code. But it’s quite light weight. It also provides the following advantages: 1-       Reliability : If a domain crashes, it can be unloaded. Hence doesn’t affect the other assemblies. 2-       Efficiency : Loading all assemblies in one domain can be cumbersome and can make the process heavy but Appdomains are efficient in this manner. Important properties of AppDomain: ApplicationIdentity , ApplicationTrust , BaseDirectory , CurrentDomain , DomainManager , DomainDirectory , Evidence , FriendlyName , ID , RelativeSearchPath , SetupInformation , ShadowCopyFiles . Important methods of AppDomain: ApplyPolicy , CreateCOMInstanceFrom , CreateDomain , CreateInstance (Assembly). To create an AppDomain: AppDomain adomain = AppDomain.CreateDomain(“D”); To execute an assembly:...

ASP.NET Working With Data-Bound Web Server Controls

Suppose we have: List<Car> vCars = new List<Car>(); There are three types of databound controls: Simple databound controls(List, AdRotater), Composite data bound controls(GridView, DetailsView, FormView that inherit from CompositeDataBoundControl), and Hierarchal data bound controls (TreeView, Menu).   DataBoundControl has a DataBind method that can be used when data is ready. It calls DataBind for child controls as well. Page.DataBind() will call DataBind for all child controls. Using DataSource Objects:                                       BaseDataBound control exposes DataSource property that accepts objects that implement IEnumerable , IListSource , IDataSource , or IHierarchalDataSource . DataSourceID accepts ID of SqlDataSource . If both specified Data...