我在数据库&列表框中插入值检索按钮单击上的文本。但我收到以下错误
对象引用未设置为实例 对象
所以“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);
...
}
答案 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控件在按下按钮时实际上没有选择项目。