在做连接数据库表,在页面上用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 控件动态加载的更多相关文章

  1. Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子

    Delphi7 第三方控件1stClass4000的TfcImageBtn按钮控件动态加载jpg图片例子 procedure TForm1.Button1Click(Sender: TObject); ...

  2. easyui控件的加载顺序

    使用easyui做布局时,会模仿窗口程序界面,做出一些较复杂的布局.按由外层到内层的顺序: (最外层)panel->tabs->tabs1 ->tabs2->layout-&g ...

  3. 重新想象 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 ...

  4. 使用DevExpress.XtraTabbedMdi.XtraTabbedMdiManager控件来加载MDI窗体

    使用DevExpress.XtraTabbedMdi.XtraTabbedMdiManager控件来加载MDI窗体     [csharp] view plaincopyprint? <SPAN ...

  5. asp.net向后台传参数动态加载图片

    //向后台传参数动态加载图片 $(function() { $("#Button1").click(function() { var stockcode = getUrlParam ...

  6. asp.net 在repeater控件中加按钮

    在repeater中加入方法有两种方法: 第一种:是对repeater控件的行添加OnItemCommand事件,添加方法也是有两种 1.在设计页面中,选中repeater控件右击==>属性== ...

  7. WPF 修改屏幕DPI,会触发控件重新加载Unload/Load

    修改屏幕DPI,会触发控件的Unloaded/Loaded 现象/重现案例 对Unloaded/Loaded的印象: FrameworkElement, 第一次加载显示时,会触发Loaded.元素被释 ...

  8. 在WinForm应用程序中,使用选项卡控件来加载不同的Form界面!

    TabPage tp=new TabPage(); your选项卡控件.Controls.Add(tp); From1 frm=new Form1(); frm.TopLevel = false; f ...

  9. 【高德地图API】Pivot控件中加载地图并禁止Pivot手势

    如题,解决方案,参考[Windows phone应用开发[20]-禁止Pivot手势]http://www.cnblogs.com/chenkai/p/3408658.html. xaml代码清单   ...

随机推荐

  1. jQuery ajax中的参数含义

    所有options均可选,下面简要说明每个option 1.async 默认为true,即请求为异步请求,这也是ajax存在的意义.但同时也可以将这个参数设置为false,实现同步请求.(同步请求会锁 ...

  2. <JZOJ5944>信标

    emmm树形dp?好像是的 搬一个题解证明过来 由于在n>1时答案至少为1,我们枚举一个必须放的根, 所有深度不同的点就被区分开了. 设一个节点有c个儿子, 发现必须在其中至少c−1个儿子的子树 ...

  3. 使用GitBook编写项目文档

    GitBook简介 GitBook 是使用 GitHub / Git 和 Markdown(或AsciiDoc)构建漂亮书籍的命令行工具(和Node.js库): GitBook 可以将您的内容作为网站 ...

  4. IOUtils和FileUtils的学习笔记

    pom文件导入依赖import org.apache.commons.io.FileUtils; <dependency> <groupId>commons-io</gr ...

  5. 通过virt-manager给Windowsxp系统配置virtio驱动

    在虚拟机的detail上添加一个硬件设备. 下载virtio.iso文件,我使用的版本126,具体的virtio驱动放到了10.2上的itest的目录中,使用可以找. 在配置中,添加virtio硬盘. ...

  6. Dungeon Master (三维BFS)

    题目: You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is composed o ...

  7. Ubuntu18.04安装Fabric

    本文介绍如何在Ubuntu18.04中搭建Fabric1.4实验环境,默认使用root用户. 1.安装Golang 首先下载Golang安装包,安装包可以从这里下载.这里下载的是go1.13.4.li ...

  8. 机器学习 —— 数据预处理

    对于学习机器学习算法来说,肯定会涉及到数据的处理,因此一开始,对数据的预处理进行学习 对于数据的预处理,大概有如下几步: 步骤1 -- 导入所需库 导入处理数据所需要的python库,有如下两个库是非 ...

  9. html|Area

    http://tomys.win/   HTML图片热区Area map的用法只是在上学的时候学习到过,在实际工作中一直没用过,如果 不是这次紧急任务,可能永远都不会想起这个功能.在一些特殊的html ...

  10. Day 1 模拟

    1. P1088 火星人 利用STL中的next_permutation();函数求一种排列的下一种排列,循环m次即为答案.(STL大法好~~C++是世界上最好的语言~~逃 #include < ...