-2
DataSet ds = new DataSet();
DataTable dt = new DataTable();
string sql = "Select * from MenuControl";
SqlDataAdapter da = new SqlDataAdapter(sql, con);
da.Fill(ds);
dt = ds.Tables[0];
foreach (DataRow dr in dt.Select("ParentId=" + 0))
{
    if (dr["MenuName"] != null && dr["MenuId"] != null && dr["LocationUrl"] != null)
    {
        menuBar.Items.Add(new MenuItem(dr["MenuName"].ToString(), dr["MenuId"].ToString(), "", dr["LocationUrl"].ToString()));
    }

}
foreach (DataRow dr in dt.Select("ParentId>" + 0))
{
    if (dr["MenuName"] != null && dr["MenuId"] != null && dr["LocationUrl"] != null)
    {
        MenuItem mnu = new MenuItem(dr["MenuName"].ToString(), dr["MenuId"].ToString(), "", dr["LocationUrl"].ToString());


        if (dr["ParentId"] != null)
        {
            menuBar.FindItem(dr["ParentId"].ToString()).ChildItems.Add(mnu);
        }
    }
}

这是错误:

    System.NullReferenceException: Object reference not set to an instance of an object.
if (dr["ParentId"] != null)
Line 56:                 {
Line 57:                     menuBar.FindItem(dr["ParentId"].ToString()).ChildItems.Add(mnu);
Line 58:                 }
Line 59:             }   
4

1 回答 1

0

如果FindItem 返回null?在设置子项之前添加空检查

var item = menuBar.FindItem(dr["ParentId"].ToString());
if(item !=null)
  item.ChildItems.Add(mnu);

您可能需要查找FindItem在您的应用程序中使用的控件的文档,根据您需要提供值路径的Menu.FindItem"rootname,child1,child11"方法,但这取决于您工作的应用程序类型和您使用的控件。

于 2013-10-13T10:37:06.843 回答