2012-04-24 1 views
2

У меня есть GridView, состоящий из двух полей базы данных, заполненных хранимой процедурой, а затем три поля для ввода пользователя (два элемента управления флажком и одно текстовое поле), когда я нажимаю на сохранение Я могу получить информацию из трех элементов управления, но ничего из двух, которые были заполнены через базу данных. Как я могу получить первые два поля?GridView не возвращает строки данных, когда происходит событие OnClick

<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> 

то значения доступны ...

ответ

0

Try:

<%# Bind("CodeViolationCited") %> 

Вместо

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

Eval является одним из способов, связать двухсторонняя.

See Microsoft's documentation for data-binding expressions

+0

Изменение его до метки «объекта» сделал его доступным ... Я DBA, что было предложено создать веб-сайт, так что ... это работает, я двигаюсь вперед с ним :) – Grixxly

+0

Неплохо для DBA :) – Ulises