Filtering and paging data
Paging and filtering are features that help users navigate through large lists of data.
Filters allow users to limit which data is displayed directly on the live site. The system provides several built-in filters for various types of data, and also allows developers to create custom filters. Filters connect to data sources, and dynamically generate additional conditions that the system applies when loading data.
Pagers separate lists of data into multiple pages and provide navigation between the pages. To implement paging, connect a Universal pager to your listing components. You have full control over the appearance of the pager (the design is based on transformations). See the documentation of the UniPager control for details.
Note: When adding filters or pagers to lists of data, we strongly recommend using a separate data source web part connected to Basic listing web part. Because of differences in the life cycle of individual components, filters and pagers may not work correctly in all possible scenarios for web parts with built-in data sources.
The diagram below illustrates how to link together data web parts with a pager and filter. You can place the web parts anywhere on the same page without any change in functionality. The captions at the beginning and end of the lines between the web parts show the properties that connect the components. The linked properties must have identical values.
Data loading when using paging
By default, page and query data sources load data per-page when you connect a Universal pager. Instead of retrieving the full data for all pages, the data source loads and caches individual pages separately, which reduces the initial load time. You can disable per-page loading through the Load pages individually property of data source web parts (in the System settings category).
Note: To use per-page loading for query and page attachment data sources, you need to fill in values into the ORDER BY expression and Selected columns properties.
Example
The following example demonstrates how to provide filtering and paging functionality for a list of product data. You can use the same approach for any type of data.
Note: The example works with product pages from the sample Corporate site.
Creating the product list
Start by creating a page with components that generate a basic list of products:
Open the Pages application.
Create a new page on your website.
Open the Design tab.
Add the Products data source web part onto the page.
Leave the default values in the Web part properties dialog and click OK.
Add the Basic repeater web part below the data source.
Set the following properties for the Basic repeater:
- Data source name: ProductsDataSource (the default ID of the Products data source web part)
- Transformation name: CMS.Product.Default
Save & Close.
The data source loads all product pages on the website, and the connected Basic repeater displays the data on the page.
Adding a filter
The system provides a default filter that allows users to limit which products the page displays (based on various criteria). To integrate the filter:
- Add the Product filter web part above the Basic repeater.
- Set the web part’s Filter name property to ProductFilter.
- Click OK.
- Configure (double-click) the Products data source web part.
- Type the filter’s name (ProductFilter) into the data source’s Filter name property.
- Click OK.
The filter is now connected to the data source web part. The data source loads a limited set of items according to the selected filter options.
You can try out the filter on the live site. For example, use the filter to display only products that have the Featured Status and sort the items by price from high to low.
Setting up paging
Paging can be useful when displaying a large number of records. To add a pager to the list of products:
Add the Universal pager web part onto the page, below the Basic repeater.
Set the following properties for the pager:
- Target control name: BasicRepeater (the default ID of the Basic repeater web part)
- Page size: 3
- Paging mode: Postback
- Pager layout transformation: CMS.PagerTransformations.General-PagerLayout
Click OK.
The Universal pager connects to the Basic repeater and separates the displayed data into multiple shorter pages.
You can try out the pager on the live site. The page now only includes up to 3 products, and allows users to switch between pages.