前臺代碼:
復制代碼 代碼如下:
table style="width: 100%;">
tr>
td>
搜索字: asp:TextBox ID="TextBox1" runat="server">/asp:TextBox>
asp:Button ID="Button1" runat="server" Text="搜索" OnClick="Button1_Click" />
/td>
/tr>
tr>
td>
div id="divmain" runat="server"> /div>
/td>
/tr>
tr>
td>
asp:Button ID="btnFirst" runat="server" Text="首頁" OnClick="btnFirst_Click" />
asp:Button ID="btnPro" runat="server" Text="上一頁" OnClick="btnPro_Click" />
asp:Button ID="btnNext" runat="server" Text="下一頁" OnClick="btnNext_Click" />
asp:Button ID="btnLast" runat="server" Text="末頁" OnClick="btnLast_Click" />
nbsp;asp:Label ID="labCountPage" runat="server">/asp:Label>
asp:Label ID="labpage" runat="server">/asp:Label>
asp:TextBox ID="TextBox2" runat="server" Width="16px">/asp:TextBox>
asp:Button ID="btnGo" runat="server" OnClick="btnGo_Click" Text="Go" />
/td>
/tr>
/table>
后臺代碼:
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState["pageIndex"] = 1;
dataPage();
}
}
private void dataPage()
{
string constr = @"data source=.;initial catalog=News;user id=sa;password=111111;";
SqlConnection conn = new SqlConnection(constr);
conn.Open();
SqlCommand cmd = conn.CreateCommand();
#region 用存儲過程實現(xiàn)數(shù)據(jù)分頁效果
//cmd.CommandType = CommandType.StoredProcedure;
//cmd.CommandText = "Pro_SelectNewsPage";
//cmd.Parameters.AddWithValue("@pageIndex", Convert.ToInt32(ViewState["pageIndex"]));
//cmd.Parameters.AddWithValue("@pageSize", 3);
//SqlParameter parm = new SqlParameter("@count", SqlDbType.Int);
//cmd.Parameters.Add(parm);
//parm.Direction = ParameterDirection.Output;
#endregion
#region 傳遞SQl語句實現(xiàn)分頁并對搜索實現(xiàn)分頁默認顯示兩條記錄
cmd.CommandType = CommandType.Text;
cmd.CommandText = "select top 2 * from (select * from T_News where NewsTitle like @title) as t where t.Id not in(select top ((@pageIndex-1)*2) t.Id from (select * from T_News where NewsTitle like @title) as t) order by t.Id";
cmd.Parameters.AddWithValue("@pageIndex", Convert.ToInt32(ViewState["pageIndex"]));
cmd.Parameters.AddWithValue("@title","%"+TextBox1.Text.Trim()+"%");
#endregion
SqlDataAdapter adapter = new SqlDataAdapter(cmd);
DataTable dt = new DataTable();
adapter.Fill(dt);
//ViewState["pageCount"] = parm.Value;
cmd.CommandText = "select count(*) from T_News where NewsTitle like @titles";
cmd.Parameters.AddWithValue("@titles", "%" + TextBox1.Text.Trim() + "%");
int sum = Convert.ToInt32(cmd.ExecuteScalar());
if (sum % 2 == 0)
{
ViewState["pageCount"] = sum/2;
}
else
{
ViewState["pageCount"] = sum / 2 + 1;
}
conn.Close();
conn.Dispose();
StringBuilder sb = new StringBuilder();
sb.Append("table>");
foreach (DataRow row in dt.Rows)
{
sb.Append("tr>td>"+row["NewsTitle"].ToString()+"/td>");
sb.Append("td>" + row["NewsContent"].ToString() + "/td>");
sb.Append("td>" + row["CreateTime"].ToString() + "/td>/tr>");
}
sb.Append("/table>");
divmain.InnerHtml = sb.ToString();
labCountPage.Text = "總共" + ViewState["pageCount"] + "頁";
labpage.Text = "當前第" + ViewState["pageIndex"] + "頁";
}
protected void Button1_Click(object sender, EventArgs e)
{
ViewState["pageIndex"] = "1";
dataPage();
}
protected void btnFirst_Click(object sender, EventArgs e)
{
ViewState["pageIndex"] = "1";
dataPage();
}
protected void btnPro_Click(object sender, EventArgs e)
{
int index = Convert.ToInt32(ViewState["pageIndex"]);
index--;
if (index >= 1)
{
ViewState["pageIndex"] = index;
dataPage();
}
}
protected void btnNext_Click(object sender, EventArgs e)
{
int index = Convert.ToInt32(ViewState["pageIndex"]);
index++;
if (index = Convert.ToInt32(ViewState["pageCount"]))
{
ViewState["pageIndex"] = index;
dataPage();
}
}
protected void btnLast_Click(object sender, EventArgs e)
{
ViewState["pageIndex"] =ViewState["pageCount"];
dataPage();
}
protected void btnGo_Click(object sender, EventArgs e)
{
int i=Convert.ToInt32(TextBox2.Text);
if (i > 0 i = Convert.ToInt32(ViewState["pageCount"]))
{
ViewState["pageIndex"] = i;
dataPage();
}
}
您可能感興趣的文章:- DWZ table的原生分頁淺談
- 利用js制作html table分頁示例(js實現(xiàn)分頁)
- bootstrap table 服務器端分頁例子分享
- JS代碼實現(xiàn)table數(shù)據(jù)分頁效果
- 對數(shù)據(jù)進行分頁顯示到table中的實現(xiàn)方法