【发布时间】:2016-08-06 16:03:52
【问题描述】:
我正在尝试单击或双击以在我的 listview 上工作,而我的 listview1_1 单击似乎不起作用。每当我单击所选项目时,都不会弹出消息框。我在创建点击事件时遵循了通常的格式,但这似乎不起作用。是因为我将数据库中的数据加载到列表视图中,而不是我在列表视图中创建的数据吗?非常感谢!
using System;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace sundayschoolproject
{
public partial class Form1 : Form
{
string con = ("Data Source=ZTABASSUM\\SQLEXPRESS01;Initial Catalog= Sunday School;Integrated Security=True");
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
listView1.GridLines = true;
listView1.View = View.Details;
//Add Columns
listView1.Columns.Add("ParentName", 100);
listView1.Columns.Add("Address", 150);
listView1.Columns.Add("City", 100);
listView1.Columns.Add("State", 50);
listView1.Columns.Add("Zipcode", 100);
listView1.Columns.Add("Phone", 150);
}
private void button1_Click(object sender, EventArgs e)
{
string sql = ("Select * from Family");
SqlConnection connection = new SqlConnection(con);
SqlCommand cmd = new SqlCommand(sql, connection);
connection.Open();
SqlDataReader dr = cmd.ExecuteReader();
listView1.Items.Clear();
while (dr.Read())
{
ListViewItem lv = new ListViewItem(dr.GetString(0));
lv.SubItems.Add(dr.GetString(1));
lv.SubItems.Add(dr.GetString(2));
lv.SubItems.Add(dr.GetString(3));
lv.SubItems.Add(dr.GetString(4));
lv.SubItems.Add(dr.GetString(5));
listView1.Items.Add(lv);
}
dr.Close();
connection.Close();
}
private void listView1_Click(object sender, MouseEventArgs e)
{
if (listView1.SelectedItems.Count > 0)
{
MessageBox.Show("You clicked " + listView1.SelectedItems[0].Text);
}
else
{
MessageBox.Show("Please select an item");
}
}
}
}
【问题讨论】:
-
listview1_click。试了调试,没有报错!
-
是的,有两个,基于 if else 语句中选择的内容。
-
listView1.SelectedItems.Count 在点击前等于零
-
是的,它似乎突出显示并执行。但是,前面的代码 lv.SubItems.Add(dr.GetString(#)) 有一个 invaldcastexception。这可能是问题吗?
-
不,我没有设置多选属性。这应该解决问题吗?
标签: c# sql .net sql-server visual-studio