Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
The navigation menu and listing controls in EPiServer CMS are used for many purposes, for example the creation of listings and website navigation through a top menu and submenus. This document provides an introduction to the EPiServer menu and listing controls available when developing with EPiServer for creating lists of pages, lists of recent news items and navigational menus. The EPiServer menu and listing controls have access to the EPiServer Data Source controls, making them an important part of the website.
There are many attributes and functions available to the web control, these can be accessed in the code-behind by typing in the control ID and through intellisense a list of the controls attributes and methods is displayed for selection.
The EPiServer menu and listing controls can handle a collection of pages contained in your EPiServer site. They can obtain this collection in different ways, by setting the following attributes for the listing control:
EPiServer controls lists are ASP.NET “Templated Controls”. The output generated by EPiServer and ASP.NET web controls is performed and controlled via templates. The templates allow you to control the rendering of data from the control. The templates provide various options and there is a certain way to utilize them. A key aspect of using the templates is specifying the appearance of the data bound to the control.
In the code example below, the PageLink property of the the MenuList control is assigned the site’s start page, which will be the root page to read data from. To render the contents of PageLink we insert the PageLink property between the template tags <ItemTemplate> and </ItemTemplate>.
<episerver:MenuList PageLink="<%#EPiServer.Core.PageReference.StartPage%>" runat="server" ID="Menu"> <ItemTemplate> <episerver:property ID="Property1" CssClass="NormalLink" PropertyName="PageLink" runat="server"/> </ItemTemplate> </episerver:MenuList>
The EPiServer CMS “all-in-one” listing controls are implemented according to the .NET concept of templated controls, see the ASP.NET Web Server Controls Templates. The rendering of data from EPiServer list and menu controls is carried out through the web controls’ templates, see Templates Introduction for more information about the actual templates and what they do. For further information about deciding which template to use, refer to the relevant web control descriptions below.
When building EPiServer solutions the MenuList and PageList web controls are frequently used to create navigation on a main and sublevel. The NewsList control is frequently used when developers need to render different markup for the first pages in a list of pages.
As each control is designed for a certain type of list, it is recommended that you familiarize yourself with all the controls before starting up development.
The following basic approaches can be used for when developing with the EPiServer listing controls types of lists:
EPiServer uses the following menu and listing web controls:
EPiServer:MenuList | Renders a menu list of top level items, useful for navigations that contain a top level menu displaying subtrees when a user clicks it. |
EPiServer:PageList | Controls rendering a page list, extends PageList with templates. Supports paging. |
EPiServer:NewsList | Control for rendering news list with specialized template for top level news. |
EPiServer:PageTree | Control for rendering page trees, extends PageTreeData with templates. |
The PageList control is usually used to list EPiServer pages, and is very similar to other data controls, such as asp.Repeater. It has some built-in features that make it easy to use in certain scenarios, for example, you can easily filter the data and add paging to it.
The following public properties are the most used:
EPiServer:PageList Properties | Description |
---|---|
MaxCount | The number of PageData objects (EPiServer pages) to list. |
PageLink | The root page to get children from. |
PageLinkProperty | The page property, gets the children of that page. |
PagesPerPagingItem | When paging is enabled, how many PageData objects per page. |
Paging | Controls if paging is used. Set to true to enable paging. |
PublishedStatus | Takes a PagePublishedStatus enum. Default is published. |
RequiredAccess | Takes an AccessLevel enum. Default is read. |
SkipCount | Skip the first x pages. Useful when doing something else with the first x number of pages. |
SortBy | Sort after an EPiServer property. |
SortDirection | Takes a FilterSortDirection enum (remember to add EPiServer.Filters). |
SortOrder | Takes a FilterSortOrder enum. |
You can use the following templates:
EPiServer:PageList Templates | Description |
---|---|
FooterTemplate | Template for listing a footer. |
HeaderTemplate | Template for listing a header. |
ItemTemplate | The default template for pages. |
PagingFooterTemplate | Footer template for the paging items. |
PagingHeaderTemplate | Header template for the paging items. |
See the code example for the PageList control in the How To section in this Developers Guide.
The MenuList control is frequently used to create the top level menu when building the navigation in an EPiServer website. Start out with the MenuList for the top level menus, and use the PageTree control for the submenus.
The following public properties are the most used:
EPiServer:MenuList Properties | Description |
---|---|
EnableVisibleInMenu | Show pages that have the Show in menus option cleared in Edit view. |
EvaluateHasChildren | Set PageLinkProperty to automatically populate PageLink from a given property. |
ExpandAll | Expand all tree nodes. |
ExpandNodeIfStartPage | Set this property to automatically select a page when selecting the start page. |
NumberOfLevels | Set the number of levels to show in the tree. |
RequiredAccess | Set or get the level of access rights filtering that will be done. |
PageLinkProperty | Set PageLinkProperty to automatically populate PageLink from a given property. |
ShowRootPage | Show the root page. |
SortBy | Gets or sets custom sorting on a property instead of using predefined sorting by setting SortOrder. |
SortOrder | Predefined sort orders instead of using custom sorting by setting SortBy. |
SortDirection | Direction for sorting listings specified by SortBy. |
PageLink | The root page to read data from. |
You can use the following templates:
EPiServer:MenuList Templates | Description |
---|---|
FooterTemplate | The default template for a footer. |
HeaderTemplate | The default template for a heading. |
ItemTemplate | Template used for displaying items in the navigation bar. |
SelectedTemplate | Template used for displaying selected items in the navigation bar. |
SeparatorTemplate | The template used between pages. |
See the code example for the MenuList control in the How To section in this Developers Guide.
NewsList has special templates for the first four news and a default NewsTemplate, if you specify NewsTemplate it will be used as fallback for the first four templates that have not been set. If you have defined all templates except NewsTemplate, you will still only see four news (you only have definitions for the first four news).
If you have defined four templates, but only have two news pages to display, then only two news will be displayed. The NewsList control sets SortBy to “PageStartPublish” and SortDirection to Descending by default. See the NewsList class for information regarding its properties.
You can use the following templates:
EPiServer:NewsList Templates | Description |
---|---|
FirstNewsTemplate | The template for the first news item. |
SecondNewsTemplate | The template for the second news item. |
ThirdNewsTemplate | The template for the third news item. |
FourthNewsTemplate | The template for the fourth news item. |
HeaderTemplate | Default header template for news pages. |
NewsTemplate | If you specify NewsTemplate it will be used as fallback for the first four templates that have not been set. |
PagingFooterTemplate | Footer template for the paging of news items. |
PagingHeaderTemplate | Header template for the paging of news items. |
TemplateControl | Gets or sets a reference to the template that contains this control. (Inherited from Control.) |
TemplateSourceDirectory | Gets the virtual directory of the Page
or UserControl that contains the current server control. (Inherited from Control.) |
FooterTemplate | Default template for pages. |
You can use the following properties:
EPiServer:NewsList Properties | Description |
---|---|
MaxCount | The number of PageData objects (EPiServer pages) to list. |
PageLink | The root page to get children from. |
PageLinkProperty | The page property, gets the children of that page. |
PagesPerPagingItem | When paging is enabled, how many PageData objects per page. |
Paging | Controls if paging is used. Set to true to enable paging. |
PublishedStatus | Takes a PagePublishedStatus enum. Default is published. |
RequiredAccess | Takes an AccessLevel enum. Default is read. |
SkipCount | Skip the first x pages. Useful when doing something else with the first x number of pages. |
SortBy | Sort after an EPiServer property. |
SortDirection | Takes a FilterSortDirection enum (remember to add using EPiServer.Filters). |
SortOrder | Takes a FilterSortOrder enum. |
The PageTree control is often used when developing more complex menus, such as site maps.
You can use the following templates:
EPiServer:PageTree Templates | Description |
---|---|
FooterTemplate | The default template for the footer. |
HeaderTemplate | The default template for the heading. |
ItemTemplate | Template used for displaying items in the navigation bar. |
ExpandedItemTemplate | The default template for expanded pages. |
ExpandedTopTemplate | The template used between pages. |
IndentTemplate | The template for indent rendering. |
SelectedExpandedItemTemplate | The default template for selected and expanded pages. |
SelectedExpandedTopTemplate | The default template for selected and expanded top level pages. |
SelectedItemTemplate | The default template for selected pages. |
TopTemplate | The default template for top level pages. |
SelectedTopTemplate | The default template for selected top level pages. |
UnindentTemplate | The template for unindent rendering. |
You can use the following properties:
EPiServer:PageTree Properties | Description |
---|---|
EnableVisibleInMenu | Show pages that have the Show in menus option cleared in Edit view. |
EvaluateHasChildren | Set PageLinkProperty to automatically populate PageLink from a given property. |
ExpandAll | Expand all tree nodes. |
ExpandNodeIfStartPage | Set this property to automatically select a page when on start page. |
NumberOfLevels | Set the number of levels to show in tree. |
RequiredAccess | Set or get the level of access rights filtering that will be done. |
PageLinkProperty | Set PageLinkProperty to automatically populate PageLink from a given property. |
ShowRootPage | |
SortBy | Gets or sets custom sorting on a property instead of using predefined sorting by setting SortOrder. |
SortOrder | Predefined sort orders instead of using custom sorting by setting SortBy. |
SortDirection | Direction for sorting listings specified by SortBy. |
PageLink | The root page to read data from. |
For examples of how the EPiServer controls are used in a website solution, install and browse the code and markup in the EPiServer CMS demo template packages.
Last updated: Mar 25, 2013