大量文本框非空判断,如何提高灵活性?

做Winform界面的时候,上面有六个文本框需要判空,之前的思路大致是这样的,代码如下:

 1 if (txtUserName.Text.Trim() == "")
 2 {
 3     MessageBox.Show("用户名不可以为空!", "温馨提示");
 4     txtUserName.Focus();
 5 }
 6 else if (txtPassword.Text.Trim() == "")
 7 {
 8     MessageBox.Show("密码不可以为空!", "温馨提示");
 9     txtPassword.Focus();
10 }
11 else if (txtConfirmPassword.Text.Trim() == "")
12 {
13     MessageBox.Show("确认密码不可以为空!", "温馨提示");
14     txtConfirmPassword.Focus();
15 }
16 else
17 {
18     MessageBox.Show("注册成功!", "温馨提示");
19 }

代码中写了三个判断,大概就是做一个注册功能时所需要做的判空操作。可是,当我界面有六个文本框需要判空时,就觉得有点麻烦了,还要加三个if else判断。于是,就想能不能将判空操作提取出一个方法来进行呢,这样至少代码看起来不会那么冗余。于是,就有了下面的代码:

 1 bool isEmpty = CheckEmpty(txtUserName, txtPassword, txtConfirmPassword);
 2 if (isEmpty)
 3 {
 4     MessageBox.Show("注册成功!", "温馨提示");
 5 }
 

7 /// <summary> 8 /// 自定义方法,判断某文本框是否为空 9 /// </summary> 10 /// <param name="txt">要进行判断的标签</param> 11 /// <returns>是否全都不为空</returns> 12 public bool CheckEmpty(params TextBox[] txt) 13 { 14 bool flag = true; 15 for (int i = 0; i < txt.Length; i++) 16 { 17 if (txt[i].Text.Trim() == "") 18 { 19 string name = txt[i].Name; 20 //将name转换为对应label的值 21 name = Change(name); 22 MessageBox.Show(name + "不可以为空,请重新输入!","温馨提示"); 23 txt[i].Focus(); 24 flag = false; 25 break; 26 } 27 } 28 return flag; 29 } 30 31 /// <summary> 32 /// 将文本框Name值转换成对应的Label文本 33 /// </summary> 34 /// <param name="name"></param> 35 /// <returns></returns> 36 private string Change(string name) 37 { 38 switch (name) 39 { 40 case "txtUserName": 41 name = "用户名"; 42 break; 43 case "txtPassword": 44 name = "密码"; 45 break; 46 case "txtConfirmPassword": 47 name = "确认密码"; 48 break; 49 default: 50 break; 51 } 52 return name; 53 }

这样一来,判空的代码看起来就清晰多了,将需要判空的文本框当做参数传过去即可。不过,又有一个问题,我们可以看到,Change方法中将文本框Name属性值转换为对应的label文本时,每添加一个判断,必须要增加一个case,这样一来,如果有一百个判断,那代码就太长了。那么,有没有一种方法,即可以替代Switch….Case又可以缩短代码行呢?答案是:有的,用Dictionary来代替。代码如下:

 1 /// <summary>
 2 /// 将文本框Name值转换成对应的Label文本
 3 /// </summary>
 4 /// <param name="name"></param>
 5 /// <returns></returns>
 6 private string Change(string name)
 7 {
 8     Dictionary<string, string> myDic = new Dictionary<string, string>();
 9     myDic.Add("txtUserName", "用户名");
10     myDic.Add("txtPassword", "密码");
11     myDic.Add("txtConfirmPassword", "确认密码");
12     return myDic[name];
13 }

我们可以看到,Dictionary实现了同Switch一样的功能,代码从15行变成了5行,而且Switch每增加一个判断,需要增加三行代码,而Dictionary只需增加一行代码即可。到现在为止,判断这个操作看起来算是不那么麻烦了。我们知道,优秀的代码一般都是可扩展,可复用的。而目前,上面的代码并没有做到可复用。CheckEmpty方法中需要用到Change方法来转换提示信息,而Change方法中的字典是写死的。这个时候,如果想复用CheckEmpty方法就必须将Change方法拿掉,将其当做参数传过来。代码如下:

 1 bool isEmpty = CheckEmpty(TopMessage(), txtUserName, txtPassword, txtConfirmPassword);
 2 if (isEmpty)
 3 {
 4     MessageBox.Show("注册成功!", "温馨提示");
 5 }
 6 
 7 /// <summary>
 8 /// 提示信息转换
 9 /// </summary>
10 /// <returns></returns>
11 private Dictionary<string, string> TopMessage()
12 {
13     Dictionary<string, string> myDic = new Dictionary<string, string>();
14     myDic.Add("txtUserName", "用户名");
15     myDic.Add("txtPassword", "密码");
16     myDic.Add("txtConfirmPassword", "确认密码");
17     return myDic;
18 }
19 
20 /// <summary>
21 /// 自定义方法,判断某文本框是否为空
22 /// </summary>
23 /// <param name="txt">要进行判断的标签</param>
24 /// <returns>是否全都不为空</returns>
25 public bool CheckEmpty(Dictionary<string,string> myDic,params TextBox[] txt)
26 {
27     bool flag = true;
28     for (int i = 0; i < txt.Length; i++)
29     {
30         if (txt[i].Text.Trim() == "")
31         {
32             string name = txt[i].Name;
33             //将name转换为对应label的值
34             name = myDic[name];
35             MessageBox.Show(name + "不能为空,请重新输入","温馨提示");
36             txt[i].Focus();
37             flag = false;
38             break;
39         }
40     }
41     return flag;
42 }

这样,CheckEmpty方法就可以复用了。在Web应用中,文本框是有一个属性可以设置是否允许为空的,不过Winform好像还没有,觉得有必要也加上。以上只是个人思考,如有不当或可改进之处,还望不吝赐教。

posted @ 2017-12-19 15:14  Daley_dp  阅读(613)  评论(3编辑  收藏  举报