項目樣式 需求說明:1.實現新增員工 2.使用DataGrideView空間展示員工信息 3.實現刪除員工信息 4.給主窗體添加右鍵菜單,實現上班簽到和下班簽退 5.選擇簽到,必須檢索員工打卡記錄,如果已簽到,提示不能再簽到 6.選擇簽退,必須檢索員工打卡記錄,如果已簽退,提示不能再簽退 7.使用D ...
項目樣式
需求說明:1.實現新增員工
2.使用DataGrideView空間展示員工信息
3.實現刪除員工信息
4.給主窗體添加右鍵菜單,實現上班簽到和下班簽退
5.選擇簽到,必須檢索員工打卡記錄,如果已簽到,提示不能再簽到
6.選擇簽退,必須檢索員工打卡記錄,如果已簽退,提示不能再簽退
7.使用DataGrideView控制項顯示員工考勤記錄
項目開始:
首先搭好窗體,創建員工類 SE 打卡時間類
public class SE
{
public int id{ get; set; } //存儲員工工號
public string name { get; set; } //存儲員工姓名
public int age { get; set; } //存儲員工年齡
public string sex{ get; set; } //存儲員工
public int type; //存儲打卡類型1,2,3
}
public class Time
{
public DateTime start { get; set; } //存儲簽到時間
public DateTime close { get; set; } //存儲簽退時間
public int id { get; set; } //存儲打卡類型1,2,3
public string name { get; set;} //存儲員工姓名
}
然後創建泛型集合list
public List<SE> list = new List<SE>(); //存儲員工的集合
public static Dictionary<string, Time> dic = new Dictionary<string, Time>(); //存儲打卡記錄
在窗體load時間為DataGrideView綁定數據源
SE s1 = new SE();
s1.id = 111;
s1.name = "王小毛";
s1.age = 26;
s1.sex = "男";
SE s2 = new SE();
s2.id = 112;
s2.name = "周新雨";
s2.age = 22;
s2.sex = "女";
SE s3 = new SE();
s3.name = "張燁";
s3.id = 113;
s3.age = 30;
s3.sex = "男";
list.Add(s1);
list.Add(s2);
list.Add(s3);
dataGridView1.DataSource = list;
新增就是跳轉新增員工窗體
點擊新增將新員工信息保存到集合中
SE s = new SE();
s.id = Convert.ToInt32(textBox1.Text);
s.name = textBox2.Text;
s.age = Convert.ToInt32(textBox3.Text);
s.sex = textBox4.Text;
frm1.list.Add(s);
MessageBox.Show("新RR增成功!");
frm1.Show();
frm1.clear(frm1.list);
this.Close();
修改員工信息涉及到一個窗體傳值,這次我們傳的是一個SE對象
首先在修改員工信息窗體new一個新的SE對象
然後點擊主窗體的修改,跳轉修改員工信息窗體
Form3 frm = new Form3();
frm.name = dataGridView1.SelectedCells[1].Value.ToString();
foreach (SE s in list)
{
if (s.id.ToString() == dataGridView1.SelectedCells[0].Value.ToString())
{
frm.s = s;
break;
}
}
frm.f = this;
frm.Show();
this.Hide();
跳轉到修改員工信息窗體,可以在textBox編輯員工信息
點擊修改,保存數據
SE s = new SE();
s.id = Convert.ToInt32(textBox1.Text);
s.age = Convert.ToInt32(textBox3.Text);
s.sex = textBox4.Text;
for(int i = 0; i < f.list.Count; i++)
{
if (f.list[i].name == name)
{
f.list[i].age = Convert.ToInt32(textBox3.Text);
f.list[i].id = Convert.ToInt32(textBox1.Text);
f.list[i].sex = textBox4.Text;
break;
}
}
MessageBox.Show("修改成功!");
f.clear(f.list);
f.Show();
在主窗體的DataGrideView添加ContextMenuTrip,添加簽到和簽退
點擊簽到和簽退,分別在集合中添加一條數據
string name=dataGridView1.SelectedCells[1].Value.ToString();
SE s = new SE();
foreach (SE se in list)
{
if (se.name == name)
{
s = se;
break;
}
}
num = s.type;
if (num==0)
{
Time t = new Time();
t.id = Convert.ToInt32(dataGridView1.SelectedRows[0].Cells[0].Value);
t.name = dataGridView1.SelectedRows[0].Cells[1].Value.ToString();
t.start = DateTime.Now;
dic.Add(t.name, t);
s.type = 1;
MessageBox.Show("簽到成功~");
}
else
{
MessageBox.Show("你已經簽到過了");
}
同時判斷是否已簽到,簽退與之相同
點擊打卡記錄,就可以看到員工打卡的信息了
這樣,一個簡單的小程式就寫完了