我创建了一个用户控件,其中包含个人资料pix,姓名,员工编号,分支机构(类似于联系人卡片)。在表单上,我放置了flowlayoutview,并希望显示表名称用户上每一行的用户控件。
private void Users_Load(object sender, EventArgs e)
{
load_grid();
Load_UserList();
}
void Load_UserList()
{
string conn = @"Data Source=(LocalDB)\MSSQLLocalDB;Initial Catalog=ifz001;";
SqlConnection Connect = new SqlConnection(conn);
Connect.Open();
try
{
var cmdQuery = "SELECT * FROM Users";
var cmdCount = "SELECT COUNT (*) FROM Users";
SqlCommand cmdQ = new SqlCommand(cmdQuery, Connect);
SqlCommand cmdC = new SqlCommand(cmdCount, Connect);
int count = (int)cmdC.ExecuteScalar();
var ad = new SqlDataAdapter(cmdQuery, Connect);
DataSet ds = new DataSet();
DataTable dt = new DataTable();
ad.Fill(dt);
for (int i = 0; i < dt.Rows.Count ; i++)
{
UserLst1 uList = new UserLst1();
uList.Name = "userlst11" + i;
uList.FullName.Text = dt.Rows[i]["fname"].ToString();
uList.Emp_Id.Text = dt.Rows[i]["emp_no"].ToString();
uList.Department.Text = dt.Rows[i]["dept"].ToString();
uList.Branch.Text = dt.Rows[i]["brn"].ToString();
uList.ProfilePix.Image = Image.FromFile(dt.Rows[i]["img_path"].ToString());
flowLayoutPanel1.Controls.Add(uList);
}
Connect.Close();
}
catch(Exception u)
{
MessageBox.Show(u.Message);
}
}
我没有将用户控件拖放到flowLayoutPanel1中,而是使用了上面的代码将它们显示在flowLayoutPanel1中。 (UserLst1 uList = new UserLst1(); uList.Name =“ userlst11” + i;)
并且有效,在用户控件的每一行中显示所有用户详细信息。
现在的问题是;我需要在用户控件上创建一个click事件,以便将相关的用户控件ID填充到textBox1中。
用户控件-> uList.Name =“ userlst11” + i; count是表用户中的行号
如何为每个用户控件(ulist.Name)创建Click事件。
我遇到的问题是,用户控件名称的增量为uList.Name =“ userlst11” + i;。我该在哪里放置点击事件。我想要用户控件(点击)的点击事件。我觉得这篇文章不是重复的,因为我需要用户控件上的click事件,这是一个具有新名称的增量事件。
答案 0 :(得分:3)
您可以这样做:
Button btn = new Button();
btn.Click += Btn_Click;
private static void Btn_Click(object sender, EventArgs e)
{
// do your magic here
}
或更简单:
btn.Click += (s,e) => { your magic here };