DevExpress中实现GridControl的分页功能
DevExpress中如何实现GridControl的分页功能
简介:DevExpress中如何实现GridControl的分页功能,
主要是利用DataNavigator和GridControl组合,自定义事件实现分页功能
接下来,我们就去实现分页功能,先看下效果图:
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
整个分页操作,基本分三步:
一:界面层
二:代码层
三:数据库
四:调用
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
一:界面层,如图:
说明:放入一个GridControl控件(gridLogList)和DataNavigator控件(nvgtDataPager),给GridControl绑定好列,
设置DataNavigator控件属性Dock=Bottom;TextLocation=Center;TextStringFormat=第 {0}页 ,共 {1};
ShowToolTips=true;
在DataNavigator控件属性Buttons --> CustomButtons (集合) 在右侧点击按钮,打开自定义按钮对话框,如下图:
点击Add按钮,添加4个自定义按钮,分别为每一个按钮设置:
ImageIndex属性:设置显示的样式,自己根据功能设按钮样式
Tag属性:用于判断点击的按钮,四个按钮分别设置:首页:f;上一页:p;下一页:n;最后一页:l
将下图中圈中的按钮属性visible=False; 如图:
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
最主要的设置DataNavigator控件的ButtonClick事件,下面是我自己在项目中用到的,作为参考,
private void dataNavigator1_ButtonClick(object sender, DevExpress.XtraEditors.NavigatorButtonClickEventArgs e)
{
PageInfo pageInfo = dataNavigator1.Tag as PageInfo;
if (pageInfo != null)
{
//首页
if ((e.Button).ButtonType == DevExpress.XtraEditors.NavigatorButtonType.Custom && e.Button.Tag.ToString() == "f")
{
pageInfo.CurrentPage = ;
} //上一页
if ((e.Button).ButtonType == DevExpress.XtraEditors.NavigatorButtonType.Custom && e.Button.Tag.ToString() == "p")
{ if (pageInfo.HasPrevious == true)
pageInfo.CurrentPage--;
} //下一页
if ((e.Button).ButtonType == DevExpress.XtraEditors.NavigatorButtonType.Custom && e.Button.Tag.ToString() == "n")
{
if (pageInfo.HasNext == true)
pageInfo.CurrentPage++; } //最后一页
if ((e.Button).ButtonType == DevExpress.XtraEditors.NavigatorButtonType.Custom && e.Button.Tag.ToString() == "l")
{
pageInfo.CurrentPage = pageInfo.TotalPages;
}
}
QueryCriteria();//按条件执行查询
}
也 可以参考下面的代码
二:代码层
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;
- }
说明:此处只需要指定你自定义的条件就可以了,以上代码展示的只是文章图一的实现
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
好了,到这,我们的所有操作就完成了,来看下我们运行的分页效果图:
出处: https://blog.csdn.net/pengzhen8805/article/details/14169327
DevExpress中实现GridControl的分页功能的更多相关文章
- 第83节:Java中的学生管理系统分页功能
第83节:Java中的学生管理系统分页功能 分页功能一般可以做成两种,一种是物理分页,另一种是逻辑分页.这两种功能是有各自的特点的,物理分页是查询的时候,对数据库进行访问,只是查一页数据就进行返回,其 ...
- DevExpress中的gridControl选择问题
在Dev控件中,gridControl是最常用的一个了. //直接通过gridView获取当前行 dr=this.gridView1.GetDataRow(this.gridView1.Focused ...
- Asp.net EasyUI中的combogrid实现分页功能
在jquery.easyUI.js 要实现分页,必须在后台接收参数时声明两个变量:page(当前第几页),rows(每页显示多少条信息),否者easyUI前台传递不了分页参数. 这两个属性的名称在ea ...
- DevExpress中的GridControl控件设置了列Readonly后,想双击弹出明细的实现
OptionsBehavior.Editable = true时,会有二个对象触发事件:view触发ShownEditor 事件(第一单击时)和内置编辑器的DoubleClick事件所以必须处理这二个 ...
- DevExpress中获取GridControl排序之后的List
public System.Collections.IList GetGridViewFilteredAndSortedData(DevExpress.XtraGrid.Views.Grid.Grid ...
- MySql中查询语句实现分页功能
import java.util.*;import java.sql.*; public class FruitDao { private Connection conn; private ...
- devexpress中gridcontrol头部添加垂直线(右边框)
winform开发,用devexpress中的gridcontrol控件,头部默认是3D样式,当客户希望像内容一样扁平化显示且需要添加垂直线(右边框)时恶梦开始了..经过一阵摸索发现可以这样解决: 1 ...
- devexpress中gridview控件编辑时改变输入法状态
在win7环境下使用Devexpress中的SpinEdit控件,切换成中文[简/繁]输入法输入数字键时有不少输入法会重复产生数字如输入1会变成11,输入123会变成112233.使用SpinEdit ...
- sf中标准的分页功能介绍
世上本无事,庸人自扰之.我喜欢一个相对比较安静的环境去学习和工作,希望在一个掉一根针的声音都能够听到的环境中,但是有时候往往相反,一片嘈杂,我改变不了周围的环境,只能改变自己,其实这些都没有什么,也许 ...
随机推荐
- V8世界探险 (1) - v8 API概览
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/lusing/article/detai ...
- php_MVC实现步骤二
2.match_split 显示逻辑相分离 将功能强制分成两个部分,显示html文件,和逻辑PHP文件: 要求浏览器请求负责功能的PHP逻辑文件: 该PHP逻辑文件,对需要的显示内容进行载入. 逻辑P ...
- Windows 下使用 Composer 安装 thinkphp
我用 XAMPP 安装 thinkphp 会出错,所以把环境换成了 phpStudy,这样甚至不用到处找安装包,直接去官网有最新版本,PHP 版本也是比较新的. 安装 phpStudy 先去官网下载安 ...
- 从Asp .net到Asp core (第二篇)《Asp Core 的生命周期》
前面一篇文章简单回顾了Asp .net的生命周期,也简单提到了Asp .net与Asp Core 的区别,我们说Asp Core不在使用Asp.netRuntime,所以它也没有了web程序生命周期中 ...
- (五)linux 学习 --重定向
The Linux Command Line 读书笔记 - 部分内容来自 http://billie66.github.io/TLCL/book/chap07.html 文章目录 标准输入.输出.错误 ...
- python学习-61 类
类 (在python2里) 1.属性 ---数据属性 ---函数属性 查看属性字典 class chinese: rz:'huangzhong' print(chinese.__dict__) 运行结 ...
- SQL——AND、OR运算符
一.AND.OR运算符基本说明 AND : 所有条件成立,则筛选出这条记录. OR : 只要其中一个条件成立,则筛选出这条记录. 演示student表: 二.AND运算符使用 查询name = '小明 ...
- Windows 10部署教程
1. 获取主板密钥 在powershell中执行: (Get-WmiObject -query 'select * from softwareLicensingService').OA3xOrigin ...
- Wing-AEP平台LWM2M设备接入
实现Wing-AEP中国电信物联网开放平台,LWM2M设备接入 一.准备 接入模组:BC35-G 平台地址:https://www.ctwing.cn/ 点击右上角控制台 点击左侧栏点击产品中心 二. ...
- JavaScript进行UTF-8编码与解码
JavaScript本身可通过charCodeAt方法得到一个字符的Unicode编码,并通过fromCharCode方法将Unicode编码转换成对应字符. 但charCodeAt方法得到的应该是一 ...