簡體   English   中英

在分頁asp.net/c#上Gridview中復選框值的持久性

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM