关于List Control控件实现翻页操作的基本代码
2014-07-10 17:10
531 查看
功能效果图:
这是我在自己写一个项目的时候,突然List Control如果数据过多,那么在查看的时候就不方便,因此百度找到了 用这一种方式来实现如上的界面的效果
原文地址:点http://mayemfc.blog.163.com/blog/static/214969209201302752654169/
在这儿是访问数据库里面的数据,数据库连接采用odbc
1.创造工程 testDlg,在对话框头文件中定义,四个公有变量
2.在构造函数中初始化
3.添加控件,并通过类向导添加响应函数,核心代码如下:
5.添加ListShow函数的实现,通过数据库实现
这是我在自己写一个项目的时候,突然List Control如果数据过多,那么在查看的时候就不方便,因此百度找到了 用这一种方式来实现如上的界面的效果
原文地址:点http://mayemfc.blog.163.com/blog/static/214969209201302752654169/
在这儿是访问数据库里面的数据,数据库连接采用odbc
1.创造工程 testDlg,在对话框头文件中定义,四个公有变量
int pageNo; //页数编号 int pageSize; // 每页显示条数 int intStart; // 开始记录 int intEnd; // 结束记录 int max_page; // 记录最大页数
2.在构造函数中初始化
pageSize=10; pageNo=1;
3.添加控件,并通过类向导添加响应函数,核心代码如下:
void CTestDlg::OnBtnFirst() // 第一页 { if (pageNo == 1) { AfxMessageBox(_T("已是第一页")); } else { pageNo = 1; m_ctlList.DeleteAllItems(); ListShow(); } } void CTestDlg::OnBtnPageup() // 上一页 { if(pageNo==1) { AfxMessageBox(_T("已是第一页")); } if(pageNo>1) { pageNo--; m_ctlList.DeleteAllItems(); ListShow(); } } void CTestDlg::OnBtnPagedown() // 下一页 { pageNo++; if (pageNo > max_page) { pageNo--; AfxMessageBox("已是最后一页"); return; } m_ctlList.DeleteAllItems(); ListShow(); } void CTestDlg::OnBtnLast() // 最后一页 { if (pageNo == max_page) { AfxMessageBox("已是最后一页"); return; } else { pageNo = max_page; m_ctlList.DeleteAllItems(); ListShow(); } }4.在对话框初始化中设置List Control的风格
5.添加ListShow函数的实现,通过数据库实现
int i_num = 0; char chrTemp='%'; intStart = pageSize * (pageNo-1); intEnd = pageSize * pageNo; try { if(testSet.IsOpen()) { testSet.Close(); } testSet.m_strFilter.Format("学号 like '%c%s%c' ", chrTemp , "", chrTemp); testSet.Open(CRecordset::snapshot,NULL,CRecordset::none); while(!testSet.IsEOF()) // 输出匹配上查询条件用户记录,直到记录为空 { if (i_num >= intStart && i_num < intEnd) // 根据页数显示相应数据 { i_num = i_num % pageSize; CString strTemp; strTemp.Format("%d",testSet.m_column1); m_ctlList.InsertItem(i_num,strTemp); m_ctlList.SetItemText(i_num, 1,testSet.m_column2); strTemp.Format("%d",testSet.m_column3); m_ctlList.SetItemText(i_num, 2, strTemp); strTemp.Format("%d",testSet.m_column4); m_ctlList.SetItemText(i_num, 3, strTemp); if (pageNo >= 2) // 当页数为1时,i的值就是其本身,如果页数大于1时,i的值恢复到取余以前 { i_num += (pageNo -1) * pageSize; } } i_num++; testSet.MoveNext(); // 记录游标移到下一条记录 } if (i_num % pageSize == 0) { max_page = i_num / pageSize; } else { max_page = i_num / pageSize + 1; } if(testSet.IsOpen()) // 关闭记录集 { testSet.Close(); } } catch(CDBException*e) { e->ReportError (); return; } CString strShowPage, strpageNo, strMaxPage; strpageNo.Format("第 %d 页 ", pageNo); strMaxPage.Format("共 %d 页", max_page); strShowPage.Format(strpageNo + strMaxPage); GetDlgItem(IDC_STATIC_SHOWPAGE)->SetWindowText(strShowPage);
相关文章推荐
- List Control控件item的可编辑操作实现
- Asp.net 2.0 自定义控件开发[实现自动计算功能(AutoComputeControl)][示例代码下载续][重点推荐控件]
- GridView控件删除行的操作提示及自定义数据行的代码实现
- GridControl 控件-----List<T>数据源 实现主从表关系绑定
- 关于MFC里list control控件的重叠问题
- Asp.net 2.0 自定义控件开发[实现自动计算功能(AutoComputeControl)][示例代码下载续][重点推荐控件]
- List Control 最基本操作
- 关于MFC里list control控件的重叠问题
- JQuery select控件的相关操作实现代码
- Asp.net 2.0 自定义控件开发[实现自动计算功能(AutoComputeControl)][示例代码下载续][重点推荐控件]
- 使用htmlcontrol实现各种基本控件
- javascript控制服务器控件-js操作CheckBoxList实现全选、反选
- CListCtrl操作大全 List Control控件使用说明 编辑List Control里面的任何...
- 使用ASP.NET AJAX Control Toolkit中的ReorderList控件实现用鼠标拖动改变条目顺序
- javascript控制服务器控件-js操作CheckBoxList实现全选、反选
- jquery下操作HTML控件的实现代码
- 关于C#代码实现ControlTemplate
- 关于DevExpress.XtraTreeList.TreeList控件的使用——给TreeList添加RepositoryItem以实现文本编辑功能
- 【MFC】实现 List Control 翻页
- MFC ListControl控件的操作