2

ストアドプロシージャを介して入力された2つのデータベースフィールドと、保存ボタンをクリックするとユーザー入力用の3つのフィールド(2つのチェックボックスコントロールと1つのテキストボックス)で構成されるGridViewがありますが、3つのコントロールから情報を取得できますが何もありませんデータベースを介して入力された2つから。最初の2つのフィールドを取得するにはどうすればよいですか?

<asp:GridView ID="gvA1" runat="server" AutoGenerateColumns="false" DataKeyNames="CodeNo" AutoGenerateSelectButton="false" EnablePersistedSelection="True" Visible="false">
    <Columns>
        <asp:TemplateField Visible="false" >
            <ItemTemplate>
                <%#DataBinder.Eval(Container.DataItem, "CodeNo")%>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField ItemStyle-Wrap="true" ItemStyle-Width="400px" HeaderText="Violation">
            <ItemTemplate>
                <%#DataBinder.Eval(Container.DataItem, "CodeViolationCited") %>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:CheckBox ID="A1Accordion_cbPool" runat="server" Text="Pool:" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:CheckBox ID="A1Accordion_cbSpa" runat="server" Text="Spa:" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="Additional Comments" Visible="true">
            <ItemTemplate>
                <asp:TextBox ID="A1Accordion_tb" runat="server" TextMode="MultiLine"></asp:TextBox>
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
</asp:GridView>

コードビハインド:

protected void SaveAndCollapseA1(object sender, EventArgs e)
{
    //good stuff
    CheckBox myCheckBox_1 = gvA1.Rows[0].FindControl("A1Accordion_cbPool") as CheckBox;
    CheckBox myCheckBox_2 = gvA1.Rows[0].FindControl("A1Accordion_cbSpa") as CheckBox;
    TextBox myTextBox = gvA1.Rows[0].FindControl("A1Accordion_tb") as TextBox;

    //not so good stuff
    String myString1 = gvA1.Rows[0].Cells[0].ToString();
    String myString2 = gvA1.Rows[0].Cells[1].ToString();


}

私はそれを理解しましたが、リンクを介して解決策を投稿するのに十分な長さの話を聞いていませんが、列をそのように変更した場合:

<asp:label ID="lblA1CodeNo" runat="server" text='<%# Eval("CodeNo") %>'></asp:label>

その後、値が利用可能になります。

4

1 に答える 1

0

試す:

<%# Bind("CodeViolationCited") %>

それ以外の

<%#DataBinder.Eval(Container.DataItem, "CodeViolationCited") %>

評価は一方向で、バインドは双方向です。

データバインディング式については、Microsoftのドキュメントを参照してください

于 2012-04-25T02:08:41.157 に答える