0

内部にテキストボックスがあるグリッドビューがあります

ボタンクリックでこのテキストボックスの値を取得したい

しかし、私は常に「0」(デフォルト)の値を受け取ります

この問題はビューステートに関連していると思いますが、よくわかりません

私が間違っていることを教えてください。

ソースコード:

protected void Page_Load(object sender, EventArgs e)
{
    DataSet dataSet = new DataSet("MyDataSet");
    DataTable table = new DataTable();
    table.Columns.Add(new DataColumn("NameValue"));
    table.Columns.Add(new DataColumn("Number"));
    table.Columns.Add(new DataColumn("NumberValue"));
    dataSet.Tables.Add(table);

    DataRow row = dataSet.Tables[0].NewRow();
    row[0] = "Name";
    row[1] = "0";

    dataSet.Tables[0].Rows.Add(row);

    this.MyGridView.DataSource = dataSet;
    this.MyGridView.DataBind();
}

protected void Button1_Click(object sender, EventArgs e)
{
    TextBox txtsn = ((TextBox)this.MyGridView.Rows[0].FindControl("NumberTextBox"));
    string sn = txtsn.Text;
}




<body>
    <form id="form1" runat="server">
    <div>
        <asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
        <asp:GridView ID="MyGridView" AutoGenerateColumns="false" ShowHeader="false" runat="server" >
            <Columns>
                <asp:TemplateField>
                    <ItemTemplate>
                        <asp:Label ID="NameLabel" runat="server" Text='<%#Eval("NameValue")%>' />
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField>
                    <ItemTemplate>
                        <asp:TextBox ID="NumberTextBox" runat="server" Text='<%#Eval("NumberValue")%>' />
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
    </div>
    </form>
</body>
4

2 に答える 2

2

DataSource問題は、ポストバックでもグリッドを常にバインドすることです。これは、ユーザーが行ったすべての変更を上書きします。

代わりに、次のIsPostBack プロパティを使用します。

protected void Page_Load(object sender, EventArgs e)
{
    if(!IsPostback)
    {
        DataSet dataSet = new DataSet("MyDataSet");
        DataTable table = new DataTable();
        table.Columns.Add(new DataColumn("NameValue"));
        table.Columns.Add(new DataColumn("Number"));
        table.Columns.Add(new DataColumn("NumberValue"));
        dataSet.Tables.Add(table);

        DataRow row = dataSet.Tables[0].NewRow();
        row[0] = "Name";
        row[1] = "0";

        dataSet.Tables[0].Rows.Add(row);

        this.MyGridView.DataSource = dataSet;
        this.MyGridView.DataBind();
    }
}

何かが変更された場合にのみリロードする必要がありますDataSource(レコードが削除または追加された場合、ユーザーが並べ替え列をクリックした場合、またはページングがある場合)。ただし、これは適切なイベントハンドラーでのみ実行し、page_loadでは実行しないでください。したがって、このコードは、どこからでも呼び出すことができるメソッドでラップするのが最善です。

于 2012-10-18T15:22:22.473 に答える
1

ポストバックでグリッドをデータバインディングしているため、この問題が発生しています。リクエストが投稿であるかどうかを確認する必要があります。

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostback)
    {
        DataSet dataSet = new DataSet("MyDataSet");
        DataTable table = new DataTable();
        table.Columns.Add(new DataColumn("NameValue"));
        table.Columns.Add(new DataColumn("Number"));
        table.Columns.Add(new DataColumn("NumberValue"));
        dataSet.Tables.Add(table);

        DataRow row = dataSet.Tables[0].NewRow();
        row[0] = "Name";
        row[1] = "0";

        dataSet.Tables[0].Rows.Add(row);

        this.MyGridView.DataSource = dataSet;
        this.MyGridView.DataBind();
    }
}
于 2012-10-18T15:23:48.043 に答える