对象引用未设置为对象的实例“

时间:2011-03-21 11:50:18

标签: c# object-reference

我在数据库&列表框中插入值检索按钮单击上的文本。但我收到以下错误

  

对象引用未设置为实例   对象

所以“selecteditem.text”在所选项目上没有任何价值...

String selectemail = "select email_id from [property].[dbo].[user_membership]";
SqlCommand cmd = new SqlCommand(selectemail, con);
cmd.Connection.Open();

ListBox1.DataSource = cmd.ExecuteReader();
ListBox1.DataTextField = "Email_ID"; 
ListBox1.DataBind();  

//on button click//       
protected void Button1_Click1(object sender, EventArgs e)
{
   ListItem item = new ListItem();
   item.Text = ListBox1.SelectedItem.Text;(error comes here)
   ListBox2.Items.Add(item.Text);
   ListBox1.Items.Remove(item.Text);
   ...
}

2 个答案:

答案 0 :(得分:3)

这将为您停止错误:

//on button click//       
protected void Button1_Click1(object sender, EventArgs e)
{
        if (ListBox1.SelectedItem == null) return;

        ListItem item = new ListItem();
        item.Text = ListBox1.SelectedItem.Text;(error comes here)
        ListBox2.Items.Add(item.Text);
        ListBox1.Items.Remove(item.Text);
}

看起来这只是用户未在ListBox1中选择任何内容的问题。

修改


我把一个测试应用程序放在一起检查,这对我来说很好用:

    var dt = New DataTable()
    dt.Columns.Add("email_id");

    dt.Rows.Add("first");
    dt.Rows.Add("second");
    dt.Rows.Add("thrid");
    dt.Rows.Add("fourth");

    var lst = New System.Web.UI.WebControls.ListBox;

    lst.DataSource = dt;
    lst.DataTextField = "Email_ID";
    lst.DataBind();

    //lst.SelectedItem is null here
    lst.SelectedIndex = 1;

    //lst.SelectedItem is NOT null here

答案 1 :(得分:1)

调试代码,但很可能不存在的对象是ListBox1控件,或者ListBox1控件在按下按钮时实际上没有选择项目。