winform分页控件(aspnetpager分页控件)

http://www.itjxue.com  2023-02-18 18:32  来源:未知  点击次数: 

vs2010winFormPager分页怎样写代码

下面开始简单介绍一下:

既然是分页控件,说明它是个控件,因此,继承控件继承自用户控件如下:

public partial class PagerControl : UserControl

{

#region 构造函数

public PagerControl()

{

InitializeComponent();

}

}

然后就是对界面拉一些控件了,如下图:

各个控件的ID就不一个个打了,下面的代码看名称就知道了。

按下来定义几个属性(第几页,每页几条,记录总数,这几个是国际性惯例必须的)

public partial class PagerControl : UserControl

{

#region 构造函数

public PagerControl()

{

InitializeComponent();

}

.NET Winform 自定义分页控件如何在父窗体中调用?

这个并不难,跳转需要的只是指定页面的数据获取,你记录跳转按钮前的分页号,然后重新在后台请求一次数据,然后把这份数据再次绑定到dataGridView1,然后dataGridView1.DataBind()一次,这个操作就是把你刚刚绑定的数据重新刷新到你页面渲染出来。

获取数据的方法我看你的GetData里面已经有用到,我就不说了,但是你得记住一个问题,你需要验证分页号是否超出你当前数据所有页面,如果超出你需要处理一下。

c#winform DataGridView绑定数据后怎样实现分页显示?

网上的正确的,你应该先在数据库端分页,这样既可以减轻数据库压力也可以减轻WEB服务器压力.

当然,你要使用控件分页的话,只要简单设置分页的每页记数录和允许分页.最后绑定就可以了

问下C# gridControl winform 分页实现 有主从关系的

从界面可以看到,在设计时需要一个DataGridView、BindingNavigate、BindingSource控件,分别命名为dgvInfo、bdnInfo、bdsInfo。

在bdnInfo控件中添加几个用于选择页面的lable和botton,如上图所示。

设计时:

1、定义几个所需的公有成员:

int pageSize = 0; //每页显示行数

int nMax = 0; //总记录数

int pageCount = 0; //页数=总记录数/每页显示行数

int pageCurrent = 0; //当前页号

int nCurrent = 0; //当前记录行

DataSet ds = new DataSet();

DataTable dtInfo = new DataTable();

2、在窗体载入事件中,从数据源读取记录到DataTable中:

string strConn = "SERVER=127.0.0.1;DATABASE=NORTHWIND;UID=SA;PWD=ULTRATEL"; //数据库连接字符串

SqlConnection conn = new SqlConnection(strConn);

conn.Open();

string strSql = "SELECT * FROM CUSTOMERS";

SqlDataAdapter sda = new SqlDataAdapter(strSql,conn);

sda.Fill(ds,"ds");

conn.Close();

dtInfo = ds.Tables[0];

InitDataSet();

3、用当前页面数据填充DataGridView

private void InitDataSet()

{

pageSize = 20; //设置页面行数

nMax = dtInfo.Rows.Count;

pageCount=(nMax/pageSize); //计算出总页数

if ((nMax % pageSize) 0) pageCount++;

pageCurrent = 1; //当前页数从1开始

nCurrent = 0; //当前记录数从0开始

LoadData();

}

private void LoadData()

{

int nStartPos = 0; //当前页面开始记录行

int nEndPos = 0; //当前页面结束记录行

DataTable dtTemp = dtInfo.Clone(); //克隆DataTable结构框架

if (pageCurrent == pageCount)

nEndPos = nMax;

else

nEndPos = pageSize * pageCurrent;

nStartPos = nCurrent;

lblPageCount.Text = pageCount.ToString();

txtCurrentPage.Text = Convert.ToString(pageCurrent);

//从元数据源复制记录行

for (int i = nStartPos; i nEndPos; i++)

{

dtTemp.ImportRow(dtInfo.Rows[i]);

nCurrent++;

}

bdsInfo.DataSource = dtTemp;

bdnInfo.BindingSource = bdsInfo;

dgvInfo.DataSource = bdsInfo;

}

4、菜单响应事件:

private void bdnInfo_ItemClicked(object sender, ToolStripItemClickedEventArgs e)

{

if (e.ClickedItem.Text == "关闭")

{

this.Close();

}

if (e.ClickedItem.Text == "上一页")

{

pageCurrent--;

if (pageCurrent = 0)

{

MessageBox.Show("已经是第一页,请点击“下一页”查看!");

return;

}

else

{

nCurrent = pageSize * (pageCurrent - 1);

}

LoadData();

}

if (e.ClickedItem.Text == "下一页")

{

pageCurrent++;

if (pageCurrent pageCount)

{

MessageBox.Show("已经是最后一页,请点击“上一页”查看!");

return;

}

else

{

nCurrent=pageSize*(pageCurrent-1);

}

LoadData();

}

}

winform中的DataGridView如何实现分页(C#)

常用分页一般有两种

一是在数据库写存储过程,或利用sql语句,每次只取出N条数据。

二是将数据一次性全取出来,然后利用程序来进行分页。

第一种在数据量比较大的时候性能好点。

希望你能明白。

(责任编辑:IT教学网)

更多

相关mac苹果系统文章

推荐mac苹果系统文章