动态生成控件( 如何把代码写的更好一点 不要太多的if else)
需求动态构建控件 并根据相应类型赋予默认值
如果写死代码 就是一堆的 if else if else 写完感觉有点想吐..
请大家帮忙出出注意 该怎么规划 比较利于扩展 该用哪些设计模式? 构造者? 抽象工厂
伪代码如下
// 控件有三个属性
1 控件类型 (暂时只用文本框TextBox,下拉条ComboBox,日期框,单选框)
2 默认值类型(枚举) (纯文本,SQL语句,文本用逗号切割)
3 值内容(string)
//------------------------------------------------
//如果控件是文本框(TextBox)
//{
/*
1 默认值类型是纯文本 如值=(销售部,财务部,人事部)
控件.Text = 值
2 默认值类型是SQL语句 (第一行第一列数据) 如值 = (select count(1) from 部门)
控件.Text = 20
3 默认值类型是文本用逗号切割
返回第一个切割值 如值 = (销售部,财务部,人事部)
控件.Text = 销售部
* */
// }
//------------------------------------------------
//如果控件是下拉框(ComboBox) 默认值模式只能是SQL或者切割字符串 绑定items 项
//{
/*
1 默认值类型是纯文本 如值=(销售部,财务部,人事部)
控件.Text = 值
this.comboBox1.Items.AddRange(new object[] { "销售部,财务部,人事部" });
2 默认值类型是SQL语句 如值 DataTable dt = (select 部门名称 from 部门)
this.comboBox1.DataSource= dt
3 默认值类型是文本用逗号切割
this.comboBox1.Items.AddRange(值.Split(',');
*/
//}
//------------------------------------------------
//如果控件是日期框 默认值是文本 强转为日期时间型赋值 如果是SQL 默认值返回第一行第一列强转
//{
/*
1 默认值类型是纯文本 如值不能强转为 日期时间型报错
2 默认值类型是SQL语句 返回(第一行第一列数据) 如值不能强转为日期时间型报错
3 默认值类型是文本用逗号切割 返回第一个切割值 如值不能强转为日期时间型报错
*/
//}