简介:DevExpress中如何实现GridControl的分页功能,

主要是利用DataNavigator和GridControl组合,自定义事件实现分页功能

接下来,我们就去实现分页功能,先看下效果图:

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

整个分页操作,基本分三步:

一:界面层

二:代码层

三:数据库

四:调用

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

一:界面层,如图:

说明:放入一个GridControl控件(gridLogList)和DataNavigator控件(nvgtDataPager),给GridControl绑定好列,

设置DataNavigator控件属性Dock=Bottom;TextLocation=Center;TextStringFormat=第 {0}页 ,共 {1};

ShowToolTips=true;将下图中圈中的按钮属性visible=False;

如图:

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

二:代码层

1.定义变量

        //页行数
public int pagesize = 20;
//当前页
public int pageIndex = 1;
//总页数
public int pageCount;

2.定义方法

        /// <summary>
/// 绑定分页控件和GridControl数据
/// </summary>
/// <author>PengZhen</author>
/// <time>2013-11-5 14:22:22</time>
/// <param name="strWhere">查询条件</param>
public void BindPageGridList(string strWhere)
{
SystemOperateLog objSOL = new BLL.SystemOperateLog(); nvgtDataPager.Buttons.CustomButtons[0].Enabled = true;
nvgtDataPager.Buttons.CustomButtons[1].Enabled = true;
nvgtDataPager.Buttons.CustomButtons[2].Enabled = true;
nvgtDataPager.Buttons.CustomButtons[3].Enabled = true;
//记录获取开始数
int startIndex = (pageIndex - 1) * pagesize + 1;
//结束数
int endIndex = pageIndex * pagesize; //总行数
int row = objSOL.GetRecordCount(strWhere); //获取总页数
if (row % pagesize > 0)
{
pageCount = row / pagesize + 1;
}
else
{
pageCount = row / pagesize;
} if (pageIndex == 1)
{
nvgtDataPager.Buttons.CustomButtons[0].Enabled = false;
nvgtDataPager.Buttons.CustomButtons[1].Enabled = false; ;
} //最后页时获取真实记录数
if (pageCount == pageIndex)
{
endIndex = row;
nvgtDataPager.Buttons.CustomButtons[2].Enabled = false;
nvgtDataPager.Buttons.CustomButtons[3].Enabled = false;
} //分页获取数据列表
DataTable dt = objSOL.GetListByPage(strWhere, "", startIndex, endIndex).Tables[0]; gridLogList.DataSource = dt; nvgtDataPager.DataSource = dt;
nvgtDataPager.TextStringFormat = string.Format("第 {0}页, 共 {1}页", pageIndex, pageCount);
}

3.定义事件

        /// <summary>
/// 按钮点击事件
/// </summary>
/// <author>PengZhen</author>
/// <time>2013-11-5 14:24:25</time>
/// <param name="sender"></param>
/// <param name="e"></param>
private void nvgtDataPager_ButtonClick(object sender, NavigatorButtonClickEventArgs e)
{
ShowEvent("ButtonClick", e.Button);
} /// <summary>
/// 分页事件处理
/// </summary>
/// <param name="eventString">事件名称</param>
/// <param name="button">按钮控件</param>
/// <author>PengZhen</author>
/// <time>2013-11-5 14:25:59</time>
void ShowEvent(string eventString, NavigatorButtonBase button)
{
//string type = button.ButtonType.ToString();
NavigatorCustomButton btn = (NavigatorCustomButton)button;
string type = btn.Tag.ToString();
if (type == "首页")
{
pageIndex = 1;
} if (type=="下一页")
{
pageIndex++;
} if (type=="末页")
{
pageIndex = pageCount;
} if (type == "上一页")
{
pageIndex--;
} //绑定分页控件和GridControl数据
BindPageGridList(strWhere);
}

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

三:数据库

        /// <summary>
/// 获取记录总数
/// </summary>
public int GetRecordCount(string strWhere)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select count(1) FROM TL_SYSTEM_OPERATE_LOGS ");
if (strWhere.Trim() != "")
{
strSql.Append(" where " + strWhere);
}
object obj = _DbHelperOra.GetSingle(strSql.ToString());
if (obj == null)
{
return 0;
}
else
{
return Convert.ToInt32(obj);
}
}
/// <summary>
/// 分页获取数据列表
/// </summary>
public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("SELECT * FROM ( ");
strSql.Append(" SELECT ROW_NUMBER() OVER (");
if (!string.IsNullOrEmpty(orderby.Trim()))
{
strSql.Append("order by T." + orderby);
}
else
{
strSql.Append("order by T.ID desc");
}
strSql.Append(")AS Rowssss, T.* from TL_SYSTEM_OPERATE_LOGS T ");
if (!string.IsNullOrEmpty(strWhere.Trim()))
{
strSql.Append(" WHERE " + strWhere);
}
strSql.Append(" ) TT");
strSql.AppendFormat(" WHERE TT.Rowssss between {0} and {1}", startIndex, endIndex);
return _DbHelperOra.Query(strSql.ToString());
}

说明:数据库的操作只作为借鉴,请根据自己的表做相应的修改

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

四:调用

如文章开头第一张效果图所述,当我就行查询操作时,也就是调用分页和绑定数据,需要做的操作,如下:

        //查询条件
private static string strWhere = string.Empty; /// <summary>
/// 查询
/// </summary>
/// <author>PengZhen</author>
/// <time>2013-10-30 11:08:03</time>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btSelect_Click(object sender, EventArgs e)
{
//获取查询条件
strWhere = GetSqlWhere(); BindPageGridList(strWhere);
} /// <summary>
/// 获取查询条件
/// </summary>
/// <author>PengZhen</author>
/// <time>2013-11-5 15:25:00</time>
/// <returns>返回查询条件</returns>
private string GetSqlWhere()
{
//查询条件
string strReturnWhere = string.Empty; //用户编号
string strUserId = string.Empty; if (!string.IsNullOrEmpty(UserManage.UserID))
{
strUserId = "12";// UserManage.UserID;
}
//分系统编码
string strSubSystemCode = string.Empty; if (cbbSubSystemCode.SelectedItem != null)
{
strSubSystemCode = (cbbSubSystemCode.SelectedItem as ComboBoxData).Value;
} //功能模块
string strFunctionModule = string.Empty; if (cbbFunctionModule.SelectedItem != null)
{
strFunctionModule = (cbbFunctionModule.SelectedItem as ComboBoxData).Value;
} //数据分类
string strDataType = string.Empty; if (tcbDataType.SelectedNode != null)
{
strDataType = tcbDataType.SelectedNode.Name;
} //操作类型
string strOperatedType = string.Empty; if (cbbOperatedType.SelectedItem != null)
{
strOperatedType = (cbbOperatedType.SelectedItem as ComboBoxData).Value;
}
//开始时间
string strStartTime = string.Empty; if (!string.IsNullOrEmpty(dateStartTime.Text))
{
strStartTime = dateStartTime.Text;
}
//结束时间
string strEndTime = string.Empty; if (!string.IsNullOrEmpty(dateEndTime.Text))
{
strEndTime = dateEndTime.Text;
} //用户ID
if (!string.IsNullOrEmpty(strUserId))
{
strReturnWhere += "USER_ID='" + strUserId + "' and";
}
//分系统代码
if (!string.IsNullOrEmpty(strSubSystemCode))
{
strReturnWhere += "SYSTEM_CODE='" + strSubSystemCode + "' and";
}
//模块编号
if (!string.IsNullOrEmpty(strFunctionModule))
{
strReturnWhere += "MODULE_ID='" + strFunctionModule + "' and";
}
//数据分类代码
if (!string.IsNullOrEmpty(strDataType))
{
strReturnWhere += "DATA_CATAGORY_CODE='" + strDataType + "' and";
}
//操作类型
if (!string.IsNullOrEmpty(strOperatedType))
{
strReturnWhere += "OPERATE_TYPE='" + strOperatedType + "' and";
}
//操作时间
if (!string.IsNullOrEmpty(strStartTime) && !string.IsNullOrEmpty(strEndTime))
{
strReturnWhere += "OPERATE_DATE between '" + strStartTime + "' and '" + strEndTime + "'";
} if (!string.IsNullOrEmpty(strReturnWhere))
{
strReturnWhere = strReturnWhere.Remove(strReturnWhere.LastIndexOf("and"));
} return strReturnWhere;
}

说明:此处只需要指定你自定义的条件就可以了,以上代码展示的只是文章图一的实现

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

好了,到这,我们的所有操作就完成了,来看下我们运行的分页效果图:

DevExpress中如何实现GridControl的分页功能(组件)

DevExpress通过girdcontrol实现分页的更多相关文章

  1. DevExpress 用户控件 分页(上)

    说明:使用用户控件分页,完成后,使用时非常简单,数据绑定,调用自己写的一个事件就OK了 前期准备工作: (1)添加一个用户控件 命名PageCtrl (2)打开代码:   [csharp] view ...

  2. DevExpress 用户控件 分页(中)

    说明: 1)具体调用请关注 看DevExpress 用户控件 分页(下) datanavi_ButtonClick 是DataNavigator的ButtonClikc事件 视图设计器: 分页用户控件 ...

  3. DevExpress GridControl+UserControl实现分页

    志向不过是记忆的奴隶,生气勃勃地降生,但却很难成长. —— 莎士比亚 时隔一年,我写随笔真的很随意,想起了就来博客园写写,想不起来就任由懒惰支配着我.不过我到觉得这不是什么坏事,你不用为了完成某事而让 ...

  4. DevExpress 用户控件 分页(下)

    分页控件调用 (1)初始化时: this.pageCtrl1.pageSize = 4; (2)数据绑定时: 从数据库中获取实时的 Public void LoadData(){ //这是只写有关分页 ...

  5. 如何Windows分页控件中增加统计功能

    在我的博客里面,很多Winform程序里面都用到了分页处理,这样可以不管是在直接访问数据库的场景还是使用网络方式访问WCF服务获取数据,都能获得较好的效率,因此WInform程序里面的分页控件的使用是 ...

  6. <转>DevExpress使用经验总结

    DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件.本文主要介绍我在使用 DevExpress控件过程中,遇到或者发现的一些问题解决方案,或者也可以所示 ...

  7. DevExpress控件使用经验总结- GridView列表行号显示操作

    DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件.本文主要介绍我在使用DevExpress控件过程中,遇到或者发现的一些问题解决方案,或者也可以所示一 ...

  8. C#第三方控件的使用

    一.DEVEXPRESS的使用 官网:https://www.devexpress.com/ 入门教程:http://wenku.baidu.com/link?url=2sXEEby1ffx9JTWG ...

  9. .net_DevExpress控件使用经验总结

    (转)DevExpress控件使用经验总结DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件.本文主要介绍我在使用DevExpress控件过程中,遇到或 ...

随机推荐

  1. ImportError: libmysqlclient.so.20: cannot open shared object file: No such file or directory 解决办法

    >>> import MySQLdbTraceback (most recent call last):  File "<stdin>", line ...

  2. 前端面试题总结(一)HTML篇

    前端面试题总结(一)HTML篇 一.iframe的优缺点? 缺点: 1.会阻塞主页面的onload事件(iframe和主页面共享链接池,而浏览器对相同域的链接有限制,所以会影响页面的并行加载). 解决 ...

  3. Webpack笔记(一)——从这里入门Webpack

    准备了挺久,一直想要好好深入了解一下Webpack,之前一直嫌弃Webpack麻烦,偏向于Parcel这种零配置的模块打包工具一些,但是实际上还是Webpack比较靠谱,并且Webpack功能更加强大 ...

  4. PhoneGap 的文件 api

    一. 文件系统的请求 请求文件系统通过 window.requestFileSystem 来完函数声明如下: window.requestFileSystem(type, size, successC ...

  5. Django的开发服务的搭建和使用

    创建一个项目¶ 如果这是你第一次使用Django,你需要完成一些初始化操作. 即,你需要自己用代码来创建一个Django项目 ——一个Django实例所需的设置集合,包括数据库的配置.Django的配 ...

  6. 输出预测边界框,NMS非极大值抑制

    我们预测阶段时: 生成多个锚框 每个锚框预测类别和偏移量 但是,当同一个目标上可能输出较多的相似的预测边界框.我们可以移除相似的预测边界框.——NMS(非极大值抑制). 对于一个预测边界框B,模型会计 ...

  7. idea中使用maven

    转:https://www.cnblogs.com/kagome2014/p/8431064.html 对于新版的IDEA可以直接打开Maven项目,但是对于旧版的IDEA需要使用Maven命令生成项 ...

  8. cin,get,getline

    一.cin 1.cin使用空白(空格.制表符和换行符)来确定字符串结束的位置,并且对于换行符,cin会把换行符留在输入队列.cin读取字符串放到数组中,并自动在结尾添加空字符. 例如: ]; cin& ...

  9. JavaScript小游戏--2048(移动端)

    HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享.今天为大家介绍的事件主 ...

  10. protected internal 和internal 区别

    private:只能在本类中使用protected:在本类中及其子类中可以使用  可以跨程序集 internal:同一命名空间(程序集)中的类可以使用  限定的是只有在同一个程序集中才可以访问,可以跨 ...