0

编辑:我在指出的第一个答复中添加了 hf。这有助于解决其他一些问题,但仍然没有解决问题。

我正在尝试将列表绑定到具有大量隐藏字段(我将仅使用 50 个中的 2 个)的网格视图以进行临时保存,以便用户可以创建和删除多个项目,而无需在期间多次来回访问数据库创建。我可以绑定到 BoundFields 并从中调用;但是,当我尝试调用隐藏字段值时,它会返回为 null。我可能在绑定到隐藏字段时遇到问题。这是我的代码

ASP:

<asp:GridView ID="grdOtherCarrier" runat="server" AutoGenerateColumns="False">
<Columns>
<asp:BoundField HeaderText="Sequence" DataField="Sequence"></asp:BoundField>
<asp:BoundField HeaderText="Pay ID" DataField="PayID"></asp:BoundField>
<asp:BoundField HeaderText="Provider" DataField="Provider"></asp:BoundField>
            <asp:TemplateField HeaderText="Actions">
                <ItemTemplate>  
                    <asp:HiddenField ID="hfInsuredLastName" Value="<%#Eval("InsuredLastName")%>" runat="server" />
                    <asp:HiddenField ID="hfInsuredFirstName" Value="<%#Eval("InsuredFirstName")%>" runat="server" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

C#/后面的代码:

    protected void lblSubmitOtherCarrier_Click(object sender, EventArgs e)
    {
        List<OtherCarrier> OCList = new List<OtherCarrier>();

        OtherCarrier OC;

 foreach (GridViewRow row in grdOtherCarrier.Rows)
        {
            if (row.RowType == DataControlRowType.DataRow)
            {
                OC = new OtherCarrier();
                String Sequence = row.Cells[0].Text.ToString() ; // primary value
                String PayID = row.Cells[1].Text.ToString(); // primary value
                String Provider = row.Cells[2].Text.ToString();    // primary value

                HiddenField InsuredLastName = (HiddenField)row.FindControl("hfInsuredLastName");
                HiddenField InsuredFirstName = (HiddenField)row.FindControl("hfInsuredFirstName");

                OC.Sequence = Sequence;
                OC.PayID = PayID;
                OC.Provider = Provider;
                OC.InsuredLastname = InsuredLastName.Value.ToString();
                OC.InsuredFirstName = InsuredFirstName.Value.ToString();

                OCList.Add(OC);
            }
        }
        OC = new OtherCarrier();

        OC.Sequence = txtSequence.Text;
        OC.PayID = txtPayID.Text;
        OC.Provider = txtProvider.Text;
        OC.InsuredLastname = txtInsuredLastname.Text;
        OC.InsuredFirstName = txtInsuredFirstName.Text;
        OCList.Add(OC);

        TD.OtherCarrierList = OCList;

        grdOtherCarrier.DataSource = OCList;
        grdOtherCarrier.DataBind();

        mpeAddOtherCarrier.Hide();
        txtSequenceNo.Text = (grdOtherCarrier.Rows.Count + 1).ToString();
     }

当它从隐藏字段分配 OC.InsuredLastname 时,隐藏字段将显示为空值。要么我没有正确阅读它,要么它没有被正确写入。

4

1 回答 1

1

所以...

你正试图找到一个控件

(HiddenField)row.FindControl("InsuredLastName");

如您所见,InsuredLastName当您在 HTML 中明确说明您的控件名称为时命名:

<asp:HiddenField 
    ID="hfInsuredLastName" 
    Value="<%#Eval("InsuredLastName")%>" 
    runat="server" />

命名为hfInsuredLastName

您需要做的就是将呼叫更改为

(HiddenField)row.FindControl("hfInsuredLastName")
于 2011-06-03T16:18:26.637 回答