這個(gè)數(shù)據(jù)源,分兩部分,一是從數(shù)據(jù)類中調(diào)出數(shù)據(jù),然后在本數(shù)據(jù)源中對(duì)分頁(yè)參數(shù)以及頁(yè)面分頁(yè)輔助控件進(jìn)行操作!在前面有三個(gè)控件控制翻頁(yè),一個(gè)下拉列表,兩個(gè)LinkButton!
下面 fill() 方法調(diào)用很簡(jiǎn)單,在頁(yè)面中要重新綁定的地方 寫上 fill() 就可以了,呵呵!但是一定要寫哦,例如翻頁(yè)動(dòng)作執(zhí)行后!
下面是db類中的ds方法
public static DataTable ds(string que)
{//返回一個(gè)裝載了SQL制定留言的數(shù)據(jù)表,
OleDbConnection con = odb.con();
OleDbDataAdapter oda = new OleDbDataAdapter();
oda.SelectCommand=new OleDbCommand(que,con);
DataSet ds = new DataSet();
oda.Fill(ds,"thc");
return ds.Tables["thc"];
con.Close();
}下面方法使用的數(shù)據(jù)源就是上面的這個(gè)
private void fill()
{//做的一個(gè)方法,因?yàn)轫?yè)內(nèi)將有多次的綁定
//這里設(shè)置一個(gè)隱藏的Label,用與儲(chǔ)存當(dāng)前的頁(yè)索引
int cup = Convert.ToInt32(pagelbl.Text);
PagedDataSource ps = new PagedDataSource();//NEW一個(gè)分頁(yè)數(shù)據(jù)源
ps.DataSource = odb.ds("select * from guest order by id desc").DefaultView;//送一個(gè)SQL語句進(jìn)去,確定該數(shù)據(jù)源的數(shù)據(jù)源,有點(diǎn)繞吧,呵呵
ps.AllowPaging = true;//允許分頁(yè)
ps.PageSize = 2;//設(shè)置頁(yè)的數(shù)量
ps.CurrentPageIndex = cup-1;
if (!IsPostBack)
{//判斷頁(yè)面是否第一次載入
for (int i = 1; i <= ps.PageCount; i++)
{//循環(huán)出頁(yè)碼
pageddl.Items.Add(i.ToString());
}
}
//下面主要是控制上下翻頁(yè)按紐是否起用
pageup.Enabled = true;
pagedown.Enabled = true;
if (ps.IsFirstPage)
{//如果是最前頁(yè),上頁(yè)按紐不可用
pageup.Enabled = false;
}
if (ps.IsLastPage)
{//如果是最后頁(yè),下頁(yè)按紐不可用
pagedown.Enabled = false;
}
//設(shè)置頁(yè)碼下拉菜單當(dāng)前選中的值
pageddl.SelectedItem.Text = cup.ToString();
//終于可以綁定給DataList了
DataList1.DataSource = ps;
DataList1.DataKeyField = "id";
DataList1.DataBind();
}
再下面是翻頁(yè)事件的處理
protected void pageddl_SelectedIndexChanged(object sender, EventArgs e)
{//頁(yè)碼下拉菜單事件
pagelbl.Text = pageddl.SelectedItem.Text.ToString();
fill();
}
protected void pagedown_Click(object sender, EventArgs e)
{//下頁(yè)事件
pagelbl.Text = Convert.ToString(Convert.ToInt32(pagelbl.Text)+1);
fill();
}
protected void pageup_Click(object sender, EventArgs e)
{//上頁(yè)事件
pagelbl.Text = Convert.ToString(Convert.ToInt32(pagelbl.Text)-1);
fill();
}
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com