动态控件没有填充

时间:2013-09-24 13:22:26

标签: c# asp.net

我有一个简单的用户控件,将在页面上多次显示。所以我有一个面板循环数据集,创建UC,填充文本框和复选框,然后将其添加到面板。

面板添加了UC,但文本框值和复选框都没有更改......

foreach (Issue iss in Case.Issues)
{
    Comments comment = (Comments)LoadControl("~/UserControls/Comments.ascx");
    comment .ID = "Comment" + iss.IssueDetail.quality_control_issue_id.ToString();
    comment .Populate(iss);
    QCComments_list.Controls.Add(comment );
}

我是否必须在页面的预渲染或Onit上执行此操作,或者有一种方法来刷新UC的控件?

这是UC标记。非常简单。

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="ROI_Comments.ascx.cs" Inherits="QualityControl_UserControls.ROI_Comments" %>
<!-- Field -->
    <div id="ROI_Comment_DIV" class="field">
        <label>Corrections</label>
        <input type="text" runat="server" id="comtxt" name="comtxt"  />
        <asp:CheckBox ID="issue_critical" runat="server" Text="Critical" />
        <asp:Button runat="server" id="SaveButton" Text="Add Comment" OnClientClick="SaveComment(this);return false;"  />
        <asp:Button runat="server" id="ROICancelButton" Text="Cancel" OnClientClick="return false;"  />
        <asp:HiddenField runat="server" ID="hIssueID" />
    </div>
    <!-- /Field -->

和.cs

 public partial class ROI_Comments : System.Web.UI.UserControl
        {
            public ROI_Comments()
            {

            }

            public void Populate(cQuality_Control_Issue _comment)
            {
                try
                {
                    hIssueID.Value = _comment.IssueDetail.quality_control_issue_id.ToString();
                    comtxt.Value = _comment.IssueDetail.quality_control_issue_description;
                    comtxt.Disabled = true;
                    issue_critical.Checked = _comment.IssueDetail.quality_control_issue_critical;
                    issue_critical.Enabled = false;
                    ROICancelButton.Text = "Delete";

                }
                catch(Exception ex)
                {}
            }
        }

1 个答案:

答案 0 :(得分:0)

您所显示的内容没有明显错误,但在设置值之前可能会出现空引用异常。由于空的try / catch块,你不会知道它。使用空的try / catch永远不是一个好主意,因为你不知道是否发生了异常。