转帖地址:http://www.cnblogs.com/shawker/archive/2009/03/17/1414795.html
在项目中我们可能会经常遇到一收集多选信息的情况,比如做注册的时候要收集个人爱好,那时候大家第一个想到的肯定是CheckBoxList。那我们怎么来获取到CheckBoxList的值并且存入数据库呢??
如果我们还需要编辑用户的个人信息而其中爱好也是可以改动的,此时同样大家也会想用CheckBoxList去显示用户的各人信息,那我们又要如何将库里的值用CheckBoxList表示出来呢?? 编辑分析问题
遇到这种情况大家肯定想到for,foreach去遍历,没错这样完没有问题,不管是获取CheckBoxList的值还是设置CheckBoxList的值我们都可以用遍历去实现。而我这里将大家常用的方法总结了一下,做了两个方法。这样用起来能更方便灵活。
举个例子:我们要收集某某公司员工的信息其中一项是爱好。而且要求员工信息可以改动
我们选用了CheckBoxList来实现爱好的收集和显示
方法:
......
1.收集时,将CheckBoxList里选中的项转换成字符串,并用“,”隔开
这里只要调用方法GetChecked(CheckBoxList checkList, string separator)
就可以获取到想要的数据。然后存入数据库。
2.显示时,先从库里获取爱好的数据(刚刚用“,”隔开的字符串),
然后调用方法SetChecked(CheckBoxList checkList,string selval,string separator)
就可以将库里的数据用CheckBoxList的形式表现出来
方法的使用:
//这里获取CheckBoxList中的选中项并用","隔开
string str=GetChecked(this.checkList1, ",");
......
//这里是将str这个字符串的值又设回CheckBoxList
SetChecked(this.checkList1,str,",");
/// <summary>初始化CheckBoxList中哪些是选中了的</summary> /// <param name="checkList">CheckBoxList</param> /// <param name="selval">选中了的值串例如:"0,1,1,2,1"</param> /// <param name="separator">值串中使用的分割符例如"0,1,1,2,1"中的逗号</param> public static string SetChecked(CheckBoxList checkList, string selval, string separator) { selval = separator + selval + separator; //例如:"0,1,1,2,1"->",0,1,1,2,1," for (int i = 0; i < checkList.Items.Count; i++) { checkList.Items[i].Selected = false; string val = separator + checkList.Items[i].Value + separator; if (selval.IndexOf(val) != -1) { checkList.Items[i].Selected = true; selval = selval.Replace(val, separator); //然后从原来的值串中删除已经选中了的 if (selval == separator) //selval的最后一项也被选中的话,此时经过Replace后,只会剩下一个分隔符 { selval += separator; //添加一个分隔符 } } } selval = selval.Substring(1, selval.Length - 2); //除去前后加的分割符号 return selval; } /// <summary> /// 得到CheckBoxList中选中了的值 /// </summary> /// <param name="checkList">CheckBoxList</param> /// <param name="separator">分割符号</param> /// <returns></returns> public static string GetChecked(CheckBoxList checkList, string separator) { string selval = ""; for (int i = 0; i < checkList.Items.Count; i++) { if (checkList.Items[i].Selected) { selval += checkList.Items[i].Value + separator; } } return selval; }