0

単純にdevexpress gridviewから選択した行を取得しようとしていますが、うまくいきません。クライアント側とカスタムコールバックを試し、サーバー側を試しましたが、うまくいきませんでした.10時間かけて検索し、すべての解決策を試しました.得ましたが、何もうまくいきませんでした。誰かが私に何が欠けているのか、ヒントを教えてください。コードは次のとおりです。

default.aspx:

<asp:Content ID="HeaderContent" runat="server" ContentPlaceHolderID="HeadContent">
<script type="text/javascript">
    </script>
</asp:Content>
<asp:Content ID="BodyContent" runat="server" ContentPlaceHolderID="MainContent">
    <div>

        <dx:ASPxGridView ID="ASPxGridView1" ClientInstanceName="ASPxGridView1"  KeyFieldName="ID" AutoGenerateColumns="False" runat="server">
            <Columns>
                <dx:GridViewCommandColumn ShowSelectCheckbox="True" VisibleIndex="0" 
                    Caption="Select" Name="Select">
                </dx:GridViewCommandColumn>
                <dx:GridViewDataTextColumn Caption="ID" FieldName="pag_id_pk" Name="ID" 
                    VisibleIndex="1">
                </dx:GridViewDataTextColumn>
                <dx:GridViewDataTextColumn Caption="Name" FieldName="pag_name" Name="Name" 
                    VisibleIndex="2">
                </dx:GridViewDataTextColumn>
                <dx:GridViewDataTextColumn Caption="Title" FieldName="pag_title" Name="Title" 
                    VisibleIndex="3">
                </dx:GridViewDataTextColumn>
            </Columns>
        </dx:ASPxGridView>
        <dx:ASPxButton ID="ASPxButton1" runat="server" AutoPostBack="False" Text="Get Values" UseSubmitBehavior="False" onclick="ASPxButton1_Click" />
    </div>
</asp:Content>

default.cs:

public partial class _Default : System.Web.UI.Page
{
    DataTable table = null;
    protected void Page_Init(object sender, EventArgs e)
    {
        if (!IsPostBack && !IsCallback)
        {
            string connectionString = ...
            con.Open();
            SqlDataReader rd;
            SqlCommand cmd = new SqlCommand("SELECT * FROM [Pages]", con);
            rd = cmd.ExecuteReader();

            DataTable dt = new DataTable();
            dt.Load(rd);

            ASPxGridView1.DataSource = dt;

            Session["dt"] = (DataTable)dt;
            ASPxGridView1.DataBind();
            rd.Close();
            con.Close();
        }
    }
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void ASPxButton1_Click(object sender, EventArgs e)
    {
        List<object> indexes = new List<object>();
        for (int i = 0; i < ASPxGridView1.VisibleRowCount; i++)
        {
            if (ASPxGridView1.Selection.IsRowSelected(i))
            {
                indexes.Add(ASPxGridView1.GetRowValues(i, ASPxGridView1.KeyFieldName));
            }
        }

        foreach (var selectedKey in ASPxGridView1.GetSelectedFieldValues(ASPxGridView1.KeyFieldName))
        {
            if (!indexes.Contains(selectedKey))
                ASPxGridView1.Selection.UnselectRowByKey(selectedKey);
        }
    }

前もって感謝します...

更新:「asp:SqlDataSource」を使用すると、正常に動作します。

4

1 に答える 1

0

ポストバック/コールバック中にデータバインドを試みましたか? あなたのグリッドは、ボタンクリックイベントにある行を知らないと思います。

于 2012-12-14T17:06:09.930 に答える