Asp.net 的DropDownList 控件动态加载
在做连接数据库表,在页面上用DropDownList 下拉框查询某条数据时,因为数据库里的数据,随时都有可能增加或减少,而下拉框关联的某个字段的值并不一定是固定的。
表信息:
CREATE TABLE [dbo].[mail_type]
(
[MailNo] [varchar] () COLLATE Chinese_Taiwan_Stroke_CI_AS NOT NULL,
[MailType] [nvarchar] () COLLATE Chinese_Taiwan_Stroke_CI_AS NOT NULL,
[Remark] [nvarchar] () COLLATE Chinese_Taiwan_Stroke_CI_AS NULL,
[Status] [char] () COLLATE Chinese_Taiwan_Stroke_CI_AS NOT NULL
) GO
在页面上 MailType 字段用下拉框来绑定查询表数据
<asp:DropDownList ID="drpMailType" runat="server"></asp:DropDownList>
查询条件
if (this.drpMailType.SelectedValue.Length > )
string sqlQuery =string.Format(" AND MailType = {0}", this.drpMailType.SelectedValue.Trim());
在这里,drpMailType 的值是随着MailType字段的内容而变化的,而不是像人的性别那样,就只有“男”或“女”这2个值。
<asp:DropDownList ID="drpSex" runat="server">
<asp:ListItem Value="">--select--</asp:ListItem>
<asp:ListItem Value="男" Selected="True">男</asp:ListItem>
<asp:ListItem Value="女">女</asp:ListItem>
</asp:DropDownList>
此时的下拉框以固定的形式来写,便难以管理和维护了。
动态加载下拉框的值,便来啦:
连接数据库,获取数据:
public DataTable GetMailTypeList()
{
string cmdText = "SELECT DISTINCT MailNo,MailType FROM mail_type ORDER BY MailType";
SqlConnection myConnection = new SqlConnection(ConfigurationSettings.AppSettings["Key_Name"]);
SqlDataAdapter myCommand = new SqlDataAdapter(cmdText, myConnection);
DataSet ds = new DataSet();
DataTable dt = ds.Tables["tableName"];
return dt;
}
方法一
循环遍历获取数据,利用obj.Items.Add(new ListItem(value值, text值))来添加值
public void GetDropInfo(DropDownList obj, string firstItemText, string firstItemValue, string defValue) {
obj.Items.Clear(); // 清除加载,防止多次加载,出现重叠的状况
DataTable dt = GetMailTypeList();
if (dt != null && dt.Rows.Count > ) {
foreach (DataRow dr in dt.Rows) {
obj.Items.Add(new ListItem(dr["MailNo"].ToString() + " " + dr["MailType"].ToString(), dr["MailNo"].ToString()));
}
}
// 设置的第一个值,如“--select--”
if (firstItemText != null && firstItemValue != null)
obj.Items.Insert(, new ListItem(firstItemText, firstItemValue));
//默認值
if (!string.IsNullOrEmpty(defValue) && obj.Items.FindByValue(defValue) != null)
obj.SelectedValue = defValue;
}
obj.Items.Add(new ListItem(dr["MailNo"].ToString() + " " + dr["MailType"].ToString(), dr["MailNo"].ToString()));
可以替换成
obj.Items.Add(new ListItem(string.Format("({0}) {1}", dr["MailType"].ToString(), dr["MailTypeDesc"].ToString()), dr["MailType"].ToString()));
方法二
在方法一的基础上修改,一点点代码即可。
//把SQL语句改下 string cmdText = "SELECT DISTINCT MailType FROM mail_type ORDER BY MailType";
if (dt != null && dt.Rows.Count > ) {
obj.DataValueField = "MailType";
obj.DataTextField = "MailType";
obj.DataSource = dt.DefaultView; obj.DataBind(); }
这里的2个方法的区别,很明显的有2个,一是 添加DropdownList值的方法不同,还有一个就是DropdownList的value值和text值的不同,方法二是直接取字段的值,而方法一是字段值的组合(对表字段做一点操作,然后再存放进DropdownList中)
在Page_Load里调用方法
GetMailTypeInfo(this.drpMailType, "--select--", "", null);
在查询按钮事件中,也调用一次
GetMailTypeInfo(this.drpMailType,"--select--","",this.drpMailType.SelectedValue);
在查询按钮中调用,主要是为了实时的加载到DropdownList的所有可能的值(即经过添加与删除操作后的数据库的值),当然啦,刷新一下页面,也是可以做到这个功能滴,主要还是看个人
Asp.net 的DropDownList 控件动态加载的更多相关文章
- Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子
Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子 procedure TForm1.Button1Click(Sender: TObject); ...
- easyui控件的加载顺序
使用easyui做布局时,会模仿窗口程序界面,做出一些较复杂的布局.按由外层到内层的顺序: (最外层)panel->tabs->tabs1 ->tabs2->layout-&g ...
- 重新想象 Windows 8.1 Store Apps (81) - 控件增强: 加载本地 html, 智能替换 html 中的 url 引用, 通过 Share Contract 分享 WebView 中的内容, 为 WebView 截图
原文:重新想象 Windows 8.1 Store Apps (81) - 控件增强: 加载本地 html, 智能替换 html 中的 url 引用, 通过 Share Contract 分享 Web ...
- 使用DevExpress.XtraTabbedMdi.XtraTabbedMdiManager控件来加载MDI窗体
使用DevExpress.XtraTabbedMdi.XtraTabbedMdiManager控件来加载MDI窗体 [csharp] view plaincopyprint? <SPAN ...
- asp.net向后台传参数动态加载图片
//向后台传参数动态加载图片 $(function() { $("#Button1").click(function() { var stockcode = getUrlParam ...
- asp.net 在repeater控件中加按钮
在repeater中加入方法有两种方法: 第一种:是对repeater控件的行添加OnItemCommand事件,添加方法也是有两种 1.在设计页面中,选中repeater控件右击==>属性== ...
- WPF 修改屏幕DPI,会触发控件重新加载Unload/Load
修改屏幕DPI,会触发控件的Unloaded/Loaded 现象/重现案例 对Unloaded/Loaded的印象: FrameworkElement, 第一次加载显示时,会触发Loaded.元素被释 ...
- 在WinForm应用程序中,使用选项卡控件来加载不同的Form界面!
TabPage tp=new TabPage(); your选项卡控件.Controls.Add(tp); From1 frm=new Form1(); frm.TopLevel = false; f ...
- 【高德地图API】Pivot控件中加载地图并禁止Pivot手势
如题,解决方案,参考[Windows phone应用开发[20]-禁止Pivot手势]http://www.cnblogs.com/chenkai/p/3408658.html. xaml代码清单 ...
随机推荐
- sm3算法的简单介绍
转自:https://blog.csdn.net/hugewaves/article/details/53765063 SM3算法也是一种哈希算法,中国国家密码管理局在2010年发布,其名称是SM3密 ...
- Java IO: FileInputStream
原文链接 作者: Jakob Jenkov 译者: 李璟(jlee381344197@gmail.com) FileInputStream可以以字节流的形式读取文件内容.FileInputStream ...
- 转: zabbix3.2.1安装graphtrees插件
转自 : http://blog.csdn.net/liang_baikai/article/details/53542317 graphtree介绍 由于zabbix的图像显示一块不太友好,图像没法 ...
- Django ORM必会13条之外的查询方法
基于双下划线的查询 # 价格 大于 小于 大于等于 小于等于 filter(price__gt=') # 筛选出大于90 filter(price__lt=') # 筛选出小于90 filter(pr ...
- 正则表达式入门-python代码
题记 本文介绍了Python对于正则表达式的支持,包括正则表达式基础以及Python正则表达式标准库的完整介绍及使用示例. 正则表达式在很多的应用中都有使用到,特别是在网络爬虫中格式化html后取出自 ...
- OutputStream之flush() · 李大白写点儿啥
最近在做一个网络下载功能,I/O操作时,操作完OutputStream时写了flush(),目的是刷新输出流,将缓存写入物理设备.突然就想,这里是否需要flush()呢? 我当时的代码: 1 2 3 ...
- 手术Robot能取代医生吗?
现在,机械自动化已经成为各领域为之神往的大趋势,从工业组装,到智能物流,再到餐饮.银行服务,以及娱乐等等,管理者无不处心积虑地降低成本.提高效率,其中,一个非常重要的手段就是利用机器取代人工.医院,作 ...
- elasicsearch数据自动清理脚本
elasticsearch随着保存的数据越来越多,磁盘占用越来越大,有必要进行定期自动清理. 直接上脚本 cat es-index-clear.sh #/bin/bash #查看索引信息 #curl ...
- 5G时代,会有什么奇葩事儿?
在3GPP RAN第187次会议关于5G短码方案的讨论中,中国华为推荐的PolarCode方案获得认可,成为5G控制信道eMBB场景编码的最终解决方案.坦白讲,笔者在读这个新闻的时候,手里备着一本 ...
- 手写实现vue的MVVM响应式原理
文中应用到的数据名词: MVVM ------------------ 视图-----模型----视图模型 三者与 Vue 的对应:view 对应 te ...