微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – DetailsView绑定空数据表时的错误?

我正在使用.net 4.5,我发现了这种奇怪的行为:

标记

<asp:DetailsView ID="dtvTest" AutoGenerateRows="true" DefaultMode="Insert" runat="server" />

码:

protected void Page_Load(object sender,EventArgs e)
{
    DataTable dt = new DataTable("Test");
    dt.Columns.Add("Column",typeof(string));
    // If I uncomment the line it works!
    // dt.Rows.Add("row 1");
    dtvTest.DataSource = dt;
    dtvTest.DataBind(); 
}

结果是

Collection cannot be null. Parameter name: c

抛出dtvTest.DataBind().

如果至少有一行它可以工作!! (见评论栏).

关于如何解决/解决它的任何想法?

非常感谢

解决方法

我在最近的一个项目中遇到了同样的问题,我通过绑定空行colleciton解决了它,如下所示,(顺便说一句我在你的解决方案编译它,它工作得很好)

protected void Page_Load(object sender,EventArgs e)
    {
       DataTable dt = new DataTable("Test");
        dt.Columns.Add("Column",typeof(string));

        // If I uncomment the line it works!
        // dt.Rows.Add("row 1");

       dt.LoadDaTarow(new string[1],true);
        dtvTest.DataSource = dt;

        dtvTest.DataBind();

    }

而且无论您添加多少列,它仍然有效.

问候

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐