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代码清单 ...
随机推荐
- apache和tomcat的关系
apache和tomcat的关系: 举个例子:apache是一辆卡车,上面可以装一些东西如html等.但是不能装水,要装水必须要有容器(桶),tomcat就是一个桶(装像JAVA这样的水),而这个桶也 ...
- mysql表关联问题(第二卷:外键1对多之2)
接着上一卷内容我们继续: 上卷我用的查询语句我们可以看到全部数据,很明显这样的方式查找的数据并不详细: SELECT * FROM usr LEFT JOIN fzu ON usr.fzu = fzu ...
- docker 创建实例
docker创建mysql实例要注意表名大小写和端口号映射的问题.下面是使用文件挂载解决表名大小写问题. docker run --name mysql-1 -e MYSQL_ROOT_PASSWOR ...
- CSS--沃顿商学院网页布局
源代码: <head> 右键CSS样式--附加样式表 </head> <body> <div id="dd"> <div id ...
- Replace into 与Insert into on duplicate key update的区别
前提条件:除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用这2条语句没有意义.该语句会与INSERT相同 1. Replace into (1) 添加相同的主键 操作前 ...
- 将Hexo网站托管到Coding.net
只需要注册coding.net,然后建立一个名为用户名+coding.me的仓库即可,需要注意的是 coding.net的pages仓库只能有一个master分支 开始使用 Coding Pages官 ...
- python自动化测试技术-Allure
文末有源码 大部分人可能做的是爬虫和web,数据分析方面的工作,今天分享个在自动化测试领域python能做什么样的事情,比如下方,是用python+pytest+allure生成的精美自动化测试报告, ...
- gcc编译器常用选项的含义
-w: 关闭编译时的警告, 也就是编译后不显示任何warning,因此有时编译中会出现一些诸如数据转换之类的可忽略警告, -Wall: 显示编译后所有警告 -W: 显示警告,但是只是显示编译器认为的会 ...
- C++走向远洋——57(项目二2、动物这样叫、抽象类)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- 自己动手用java写一个hashMap
入坑java很多年了,现在总结一下自己学到的东西. 1.首先我们先来聊聊什么是HashMap? 什么是hash?hash用中文的说法就叫做“散列”,通俗的讲就是把任意长度的字符串输入,经过hash计算 ...