1

我的代码隐藏中有一个设置数据网格的函数。我创建了一个新的空白列并将其添加到我的数据网格中,并且我只想为与对象 id 匹配的一行添加一个值。出于某种原因,单元格不存储我设置的文本。有什么想法吗?

public void SetContacts(IEnumerable<User> contactList, User reqUser)
    {
        BoundColumn reqColumn = new BoundColumn();
        reqColumn.HeaderText = "";
        dgExistingContacts.Columns.Add(reqColumn);
        dgExistingContacts.DataSource = contactList;

        foreach (DataGridItem row in dgExistingContacts.Items)
        {
            if (row.Cells[0].Text == reqUser.id.ToString())
                row.Cells[6].Text = "Requestor";
        }
        dgExistingContacts.DataBind();

    }

如果有帮助,这是我的数据网格:

<asp:DataGrid runat="server" ID="dgExistingContacts" AutoGenerateColumns="false" CssClass="styledGray" HeaderStyle-CssClass="head" CellSpacing="1" CellPadding="4" GridLines="None" AlternatingItemStyle-CssClass="even" ItemStyle-CssClass="odd">
                    <Columns>
                        <asp:BoundColumn DataField="Id" Visible="false" />
                        <asp:BoundColumn DataField="Title" HeaderText="Role" />
                        <asp:BoundColumn DataField="LastName" HeaderText="Last Name" ItemStyle-Wrap="false" />
                        <asp:BoundColumn DataField="FirstName" HeaderText="First Name" ItemStyle-Wrap="false" />
                        <asp:BoundColumn DataField="Phone" HeaderText="Phone" DataFormatString="{0:(###) ###-####}" />
                        <asp:BoundColumn DataField="EmailAddress" HeaderText="Email" ItemStyle-Wrap="false" />
                    </Columns>
                </asp:DataGrid>

我觉得它应该很简单,但我不明白为什么它没有约束力。

4

3 回答 3

0

正如我所看到的 ,您正在添加一列dgExistingContacts然后分配 contactList,这意味着您首先添加列,然后在此代码中重置为前者:DataSourcedgExistingContactsDaraGridDataSource

    dgExistingContacts.Columns.Add(reqColumn);
    dgExistingContacts.DataSource = contactList;

我认为当您分配给时DataSourceGridView您在其中更改的任何内容都将被重置。所以也许通过dgExistingContacts.DataSource = contactList;从代码中删除,您的问题将得到解决。

于 2013-05-07T17:49:13.087 回答
0

尝试处理GridView'RowDataBound事件并在那里添加值。

于 2013-05-07T17:54:22.183 回答
0

我发现您必须在尝试更改内容之前绑定数据。我最终得到了这个:

public void SetContacts(IEnumerable<User> contactList, User reqUser)
{
    BoundColumn reqColumn = new BoundColumn();
    reqColumn.HeaderText = "";
    dgExistingContacts.Columns.Add(reqColumn);
    dgExistingContacts.DataSource = contactList;
    dgExistingContacts.DataBind();
    foreach (DataGridItem row in dgExistingContacts.Items)
    {
        if (row.Cells[0].Text == reqUser.id.ToString())
            row.Cells[6].Text = "Requestor";
    }
}
于 2013-05-10T18:23:14.810 回答