webabcd - 专注于asp.net

ASP.NET
从现在开始 一切都不晚
posts - 149, comments - 4064, trackbacks - 328, articles - 0
  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理
GridView既强大又好用。为了让它更强大、更好用,我们来写一个继承自GridView的控件。
[索引页]
[源码下载]


扩展GridView控件(10) - 自定义分页样式


作者:webabcd


/*正式版的实现 开始*/

介绍
扩展GridView控件:
自定义分页样式。显示总记录数、每页记录数、当前页数、总页数、首页、上一页、下一页、末页和分页按钮

使用方法(设置CustomPagerSettings复合属性):
PagingMode - 自定义分页的显示模式
TextFormat - 自定义分页的文本显示样式(四个占位符:{0}-每页显示记录数;{1}-总记录数;{2}-当前页数;{3}-总页数)


关键代码
using System;
using System.Collections.Generic;
using System.Text;

using System.Web.UI.WebControls;
using System.Web.UI;
using System.ComponentModel;
using System.Collections;
using System.Data;
using System.Web.UI.HtmlControls;

namespace YYControls.SmartGridViewFunction
{
    
/// <summary>
    
/// 扩展功能:自定义分页样式
    
/// </summary>

    public class CustomPagerSettingsFunction : ExtendFunction
    
{
        
/// <summary>
        
/// 构造函数
        
/// </summary>

        public CustomPagerSettingsFunction()
            : 
base()
        
{

        }


        
/// <summary>
        
/// 构造函数
        
/// </summary>
        
/// <param name="sgv">SmartGridView对象</param>

        public CustomPagerSettingsFunction(SmartGridView sgv)
            : 
base(sgv)
        
{
    
        }


        
/// <summary>
        
/// 扩展功能的实现
        
/// </summary>

        protected override void Execute()
        
{
            
this._sgv.InitPager += new SmartGridView.InitPagerHandler(_sgv_InitPager); 
        }


        
/// <summary>
        
/// SmartGridView的InitPager事件
        
/// </summary>
        
/// <param name="sender"></param>
        
/// <param name="row">一个 System.Web.UI.WebControls.GridViewRow,表示要初始化的页导航行</param>
        
/// <param name="columnSpan">页导航行应跨越的列数</param>
        
/// <param name="pagedDataSource">一个 System.Web.UI.WebControls.PagedDataSource,表示数据源</param>

        void _sgv_InitPager(object sender, GridViewRow row, int columnSpan, PagedDataSource pagedDataSource)
        
{
            
int recordCount = pagedDataSource.DataSourceCount;

            LinkButton First 
= new LinkButton();
            LinkButton Prev 
= new LinkButton();
            LinkButton Next 
= new LinkButton();
            LinkButton Last 
= new LinkButton();

            TableCell tc 
= new TableCell();

            row.Controls.Clear();

            tc.Controls.Add(
new LiteralControl("&nbsp"));

            
显示总记录数 每页记录数 当前页数/总页数

            
设置“首页 上一页 下一页 末页”按钮

            
添加首页,上一页按钮

            
显示数字分页按钮

            
添加下一页,末页按钮

            tc.Controls.Add(
new LiteralControl("&nbsp"));

            tc.ColumnSpan 
= this._sgv.Columns.Count;

            row.Controls.Add(tc);        
        }

    }

}


/*正式版的实现 结束*/


/*测试版的实现 开始*/

介绍
用着GridView自带的分页样式总觉得不太习惯,我们可以在PagerTemplate中来写一些自定义的样式,但是也挺麻烦的,其实我们可以扩展一下GridView,给它再增加一种分页样式


控件开发
1、新建一个继承自GridView的类。
/// <summary>
/// 继承自GridView
/// </summary>

[ToolboxData(@"<{0}:SmartGridView runat='server'></{0}:SmartGridView>")]
public class SmartGridView : GridView
{
}

2、新建一个Paging类,定义一个分页样式的枚举
using System;
using System.Collections.Generic;
using System.Text;

using System.ComponentModel;

namespace YYControls.SmartGridView
{
    
/// <summary>
    
/// 自定义分页相关
    
/// </summary>

    public class Paging
    
{
        
/// <summary>
        
/// 自定义分页样式
        
/// </summary>

        public enum PagingStyleCollection
        
{
            
/// <summary>
            
/// 不用自定义分页样式
            
/// </summary>

            None,
            
/// <summary>
            
/// 默认自定义分页样式
            
/// </summary>

            Default
        }

    }

}


3、在继承自GridView的类中加一个上面定义的枚举属性
        private Paging.PagingStyleCollection _pagingStyle;
        
/// <summary>
        
/// 自定义分页样式
        
/// </summary>

        [Description("自定义分页样式"), DefaultValue(""), Category("扩展")]
        
public Paging.PagingStyleCollection PagingStyle
        
{
            
get return _pagingStyle; }
            
set { _pagingStyle = value; }
        }

4、如果GridView使用的是数据源控件的话,计算总记录数
        /// <summary>
        
/// OnLoad
        
/// </summary>
        
/// <param name="e"></param>

        protected override void OnLoad(EventArgs e)
        
{
            
// 查找ObjectDataSource
            ObjectDataSource ods = Parent.FindControl(this.DataSourceID) as ObjectDataSource;
            
if (ods != null)
            
{
                ods.Selected 
+= new ObjectDataSourceStatusEventHandler(ods_Selected);
            }


            
base.OnLoad(e);
        }


        
private int? _recordCount = null;
        
/// <summary>
        
/// 计算总记录数
        
/// </summary>
        
/// <param name="sender"></param>
        
/// <param name="e"></param>

        private void ods_Selected(object sender, ObjectDataSourceStatusEventArgs e)
        
{
            
if (e.ReturnValue is IListSource)
            
{
                _recordCount 
= ((IListSource)e.ReturnValue).GetList().Count;
            }

        }

5、重写OnRowCreated以实现自定义分页样式
        /// <summary>
        
/// OnRowCreated
        
/// </summary>
        
/// <param name="e"></param>

        protected override void OnRowCreated(GridViewRowEventArgs e)
        
{
            
if (e.Row.RowType == DataControlRowType.Pager && PagingStyle == Paging.PagingStyleCollection.Default)
            
{
                LinkButton First 
=