Как добавить текст в метку внутри сетки из DataTable

Я хочу связать представление сетки из DataTable

    var dt = new DataTable();
    dt.Columns.Add("nrtest");
    dt.Columns.Add("asd");
    dt.Columns.Add("dsa");
    dt.Columns.Add("qwe");
    dt.Columns.Add("ewq");

    dt.Rows.Add("test1","","","","");
    dt.Rows.Add("test2","","","","");
    dt.Rows.Add("test3","","","","");


    mygrid.DataSource = dt;
    mygrid.DataBind();

Первый столбец в моей сетке содержит метку

Я хочу добавить первый столбец из datatable в первый столбец из gridview

Я пытаюсь так:

 foreach(GridViewRow gdRow in mygrid.Rows)
            {
               if (gdRow.RowType == DataControlRowType.DataRow)
                     {
             var label1 = (Label) gdRow.Cells[1].FindControl("myLabel");
                         text1.Text = text1;

             var label2 = (Label) gdRow.Cells[1].FindControl("myLabel");
                         text2.Text = text2;

             var label3 = (Label) gdRow.Cells[1].FindControl("myLabel");
                         text3.Text = text3;
           }
      }
  but it doesn't work, at the end all the labels contain text3

Моя сетка:

 <asp:GridView ID="mygrid" runat="server" AutoGenerateColumns="False" 
              Visible="True" width="600px" onrowcreated="GdOrarRowCreated">

          <Columns>
                      <asp:TemplateField >
                          <HeaderTemplate>
                   <asp:Label ID="text" runat="server" Text="text" ></asp:Label>
                          </HeaderTemplate>
                          <ItemTemplate>
                              <asp:Label runat="server" ID="myLabel" />
                          </ItemTemplate>
                      </asp:TemplateField>

  <asp:BoundField DataField="asd" Visible="True"  HeaderText="col2"/>
  <asp:BoundField DataField="dsa" Visible="True"  HeaderText="col3"/>
  <asp:BoundField DataField="qwe" Visible="True"  HeaderText="col4"/>
  <asp:BoundField DataField="ewq" Visible="True"  HeaderText="col5"/>

                       </Columns>
                    </asp:GridView>

person Alex    schedule 28.09.2012    source источник
comment
Опубликуйте свою разметку для GridView   -  person Tim B James    schedule 28.09.2012


Ответы (2)


Вы назначаете один и тот же идентификатор для всех трех ярлыков. Дайте им уникальный идентификатор, а затем попробуйте. потому что он присваивает последнее значение

хотя есть и другие проблемы с вашим кодом, вы можете попробовать что-то вроде

    var dt = new DataTable();
    dt.Columns.Add("nrtest");
    dt.Columns.Add("asd");
    dt.Columns.Add("dsa");
    dt.Columns.Add("qwe");
    dt.Columns.Add("ewq");

    dt.Rows.Add("test1", "", "", "", "");
    dt.Rows.Add("test2", "", "", "", "");
    dt.Rows.Add("test3", "", "", "", "");


    mygrid.DataSource = dt;
    mygrid.DataBind();

делайте что угодно, а затем, чтобы связать сетку, вы можете использовать цикл for, это позволит вам легче получить индекс строки, затем вы можете связать с rowindex:

    var rows =  mygrid.Rows;
    for(int i=0,j=rows.Count; i<j;i++)
    {
        var row = rows[i];
        if (row.RowType == DataControlRowType.DataRow)
        {
            var label1 = (Label)row.Cells[1].FindControl("myLabel");
            //use rowindex i and colindex "nrtest" to get data from dt
            label1.Text = dt.Rows[i]["nrtest"].ToString();
        }
    }

Код сетки останется таким же, как в вопросе

<asp:GridView ID="mygrid" runat="server" AutoGenerateColumns="False" Visible="True"
    Width="600px">
    <Columns>
        <asp:TemplateField>
            <HeaderTemplate>
                <asp:Label ID="text" runat="server" Text="text"></asp:Label>
            </HeaderTemplate>
            <ItemTemplate>
                <asp:Label runat="server" ID="myLabel" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:BoundField DataField="asd" Visible="True" HeaderText="col2" />
        <asp:BoundField DataField="dsa" Visible="True" HeaderText="col3" />
        <asp:BoundField DataField="qwe" Visible="True" HeaderText="col4" />
        <asp:BoundField DataField="ewq" Visible="True" HeaderText="col5" />
    </Columns>
</asp:GridView>
person priyanka    schedule 28.09.2012

Вы назначаете один и тот же идентификатор всем 3 ярлыкам. Дайте им уникальный идентификатор, а затем попробуйте.

person mitali    schedule 28.09.2012