在做连接数据库表,在页面上用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. 输入一个url之后到底发生了什么 - Hurry

    背景 最近学习到 nginx 方向代理发现,nginx 可以将你的请求以 http 块的 server 形式代理到请求的域名或者 ip 地址. 一个简单的 nigx 配置如下: 12345678 se ...

  2. Android开发之《异常处理》

    Android NDK(七):JNI异常处理 Android NDK开发Crash错误定位 adb logcat | ndk-stack -sym /Users/yangxin/Documents/d ...

  3. Jenkins之邮件通知

    Jenkins默认有一个邮件通知功能,但功能比较单一,能自定义的东西很少,一般使用Extended E-mail Notification插件来发送邮件,EXT Email插件功能比较多,但设置也比较 ...

  4. 关于利用glassfish部署Java EE的firstcup-war时报错

    在利用maven+glassfish打包部署Java EE的firstcup-war时报错 1.在利用glassfish部署firstcup-war.war文件时提示如下错误信息: 根据上面的错误提示 ...

  5. iOS 编程:NSURLSession

    定义:描述 Foundation 框架类在标准的网络传输协议下,用 URLs 连接因特网并与服务器交互的一整套体系. 支持的传输协议: File Transfer Protocol (ftp://) ...

  6. 8.2.2 使用Java8增强的Iterator遍历集合元素

    8.2.2 使用Java 8增强的Iterator遍历集合元素 Iterator接口方法 程序示例 Iterator仅用于遍历集合 Iterator必须依附于Collection对象 修改迭代变量的值 ...

  7. MyBatis连接MySQL8配置

    <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</a ...

  8. 設定MacOS 終端機環境 (Homebrew/zsh/oh-my-zsh/iTerm2)

    安裝Homebrew 1 ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/in ...

  9. OpenGL Panorama Player

    JMGL_PANO star_war_eve source 1 star_war_eve source 2 1. 介绍 JMGL_PANO 是Justin开源的一个全景视频播放器(Github).基于 ...

  10. 微软发布Microsoft Concept Graph和Microsoft Concept Tagging模型

    ​ Concept Graph和Microsoft Concept Tagging模型"> 当我们在讨论人工智能时,请注意,我们通常在讨论弱人工智能. 虽然我们现有的资源与之前可谓不同 ...