[英]persistence of checkbox values in Gridview on paging asp.net/c#
我想在選擇網格視圖中顯示的項目時保留復選框值。
這是gridviewpage.aspx中創建gridview的代碼:
<form id="form1" runat="server">
<div>
<asp:GridView ID="GridView1" runat="server"
AutoGenerateColumns = "False" Font-Names = "Arial"
Font-Size = "11pt" AlternatingRowStyle-BackColor = "#C2D69B"
HeaderStyle-BackColor = "green" AllowPaging ="True"
OnPageIndexChanging = "OnPaging1xxx" OnRowDataBound = "RowDataBound"
AllowSorting="True" DataKeyNames="CustomerID" DataSourceID="SqlDataSource1" >
<Columns>
<asp:BoundField ItemStyle-Width = "150px" DataField = "CustomerID"
HeaderText = "CustomerID" ReadOnly="True" SortExpression="CustomerID" />
<asp:BoundField ItemStyle-Width = "150px" DataField = "City" HeaderText = "City"
SortExpression="City"/>
<asp:BoundField ItemStyle-Width = "150px" DataField = "Country"
HeaderText = "Country" SortExpression="Country"/>
<asp:BoundField ItemStyle-Width = "150px" DataField = "PostalCode"
HeaderText = "PostalCode" SortExpression="PostalCode"/>
<asp:TemplateField>
<ItemTemplate>
<asp:CheckBox id="CheckBox1" runat="server" onclick="Check_Click(this)"/>
</ItemTemplate>
<HeaderTemplate>
<asp:CheckBox id="chkAll" runat="server" Text="Select All" onclick="checkAll(this)"/>
</HeaderTemplate>
</asp:TemplateField>
</Columns>
<AlternatingRowStyle BackColor="#C2D69B" />
<HeaderStyle BackColor="Green"></HeaderStyle>
</asp:GridView>
<asp:SqlDataSource ID="SqlDataSource1" runat="server"
ConnectionString="Data Source=SDANTURTHI-PC;Initial Catalog=ArticleDB;Integrated Security=True"
ProviderName="System.Data.SqlClient"
SelectCommand="SELECT [CustomerID], [City], [Country], [PostalCode] FROM [Customers]">
</asp:SqlDataSource>
</div>
這是gridviewpage.aspx.cs中的代碼
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.Collections;
using System.IO.Compression;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
ArrayList CheckBoxArray;
if (ViewState["CheckBoxArray"] != null)
{
CheckBoxArray = (ArrayList)ViewState["CheckBoxArray"];
}
else
{
CheckBoxArray = new ArrayList();
}
if (IsPostBack)
{
int CheckBoxIndex;
bool CheckAllWasChecked=false;
CheckBox chkAll = (CheckBox)GridView1.HeaderRow.Cells[4].FindControl("chkAll");
string checkAllIndex = "chkAll-" + GridView1.PageIndex;
if (chkAll.Checked)
{
if (CheckBoxArray.IndexOf(checkAllIndex) == -1)
{
CheckBoxArray.Add(checkAllIndex);
}
}
else
{
if (CheckBoxArray.IndexOf(checkAllIndex) != -1)
{
CheckBoxArray.Remove(checkAllIndex);
CheckAllWasChecked = true;
}
}
for (int i = 0; i < GridView1.Rows.Count; i++)
{
if (GridView1.Rows[i].RowType == DataControlRowType.DataRow)
{
CheckBox chk = (CheckBox)GridView1.Rows[i].Cells[4].FindControl("CheckBox1");
CheckBoxIndex = GridView1.PageSize * GridView1.PageIndex + (i + 1);
if (chk.Checked)
{
if (CheckBoxArray.IndexOf(CheckBoxIndex) == -1 && !CheckAllWasChecked)
{
CheckBoxArray.Add(CheckBoxIndex);
}
}
else
{
if (CheckBoxArray.IndexOf(CheckBoxIndex) != -1 || CheckAllWasChecked)
{
CheckBoxArray.Remove(CheckBoxIndex);
}
}
}
}
}
ViewState["CheckBoxArray"] = CheckBoxArray;
GridView1.DataBind();
}
protected void OnPaging1xxx(object sender, GridViewPageEventArgs e)
{
GridView1.PageIndex = e.NewPageIndex;
GridView1.DataBind();
if (ViewState["CheckBoxArray"] != null)
{
ArrayList CheckBoxArray = (ArrayList)ViewState["CheckBoxArray"];
string checkAllIndex = "chkAll-" + GridView1.PageIndex;
if (CheckBoxArray.IndexOf(checkAllIndex) != -1)
{
CheckBox chkAll = (CheckBox)GridView1.HeaderRow.Cells[4].FindControl("chkAll");
chkAll.Checked = true;
}
for (int i = 0; i < GridView1.Rows.Count; i++)
{
if (GridView1.Rows[i].RowType == DataControlRowType.DataRow)
{
if (CheckBoxArray.IndexOf(checkAllIndex) != -1)
{
CheckBox chk = (CheckBox)GridView1.Rows[i].Cells[4].FindControl("CheckBox1");
chk.Checked = true;
GridView1.Rows[i].Attributes.Add("style","background-color:aqua");
}
else
{
int CheckBoxIndex = GridView1.PageSize * (GridView1.PageIndex) + (i + 1);
if (CheckBoxArray.IndexOf(CheckBoxIndex) != -1)
{
CheckBox chk = (CheckBox)GridView1.Rows[i].Cells[4].FindControl("CheckBox1");
chk.Checked = true;
GridView1.Rows[i].Attributes.Add("style", "background-color:aqua");
}
}
}
}
}
}
protected void RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Attributes.Add("onmouseover", "MouseEvents(this, event)");
e.Row.Attributes.Add("onmouseout", "MouseEvents(this, event)");
}
}
}
它不能持久保存這些值,但是當我調試checkboxarray和viewstate["checkboxarray"]
似乎擁有正確的值。 我不明白為什么它不起作用。 請幫我。 謝謝你的期待
請注意,ViewState僅在從服務器到瀏覽器的行程中“起作用”。 您不能指望它仍會留在發回郵件中。
堅持下去將需要使用Session。
編輯
您想返回服務器的任何內容都需要以表格形式放置
->它將在Request.Form [“ blabla”]中
或在查詢字符串中(mypage.aspx?blabla = somevalue)
->將在Request.QueryString [“ blabla”]中
這是將數據從服務器獲取到頁面的僅有的兩種方法。
(附錄:
當控件觸發您在代碼隱藏的cs文件中處理的事件時,對您而言這是微不足道的。 ASP.NET將控件包裝在表單中,然后回發->您運行代碼->發送回更新的頁面)
編輯
您的復選框在Request.Form [..]中為“ CheckBox1xxx”,其中xxx為行號。 該行號對您而言將毫無意義。
我的建議是遍歷Request.Form中的值,看看哪些以“ CheckBox1”開頭(如此處 ),提取行號,獲取“ CustomerIDxxx”的值,並使用該值與正確的Record匹配。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.