在做连接数据库表,在页面上用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. C语言学习笔记之获取文件长度

    本文为原创文章,转载请标明出处 #include <stdio.h> #include <stdlib.h> int main() { FILE *inputFile; inp ...

  2. Eclipse添加comment

    1.给新增的Java类,自动生成Comment. 打开Preferences,找到Java-->Code Style -->Code Templates-->Comments--&g ...

  3. 关于(Building tool)的认识以及当下流行的Building tool有哪些?

    1.Building tool是什么? (Building tool)构建工具是一种工具,它负责构建流程的所有内容,并自动化与构建项目相关的所有内容.它致力于以下任务: 生成源代码(如果在软件项目中使 ...

  4. Dangling meta character '' near index 0

    1.replaceAll()方法报错 对字符串使用replaceAll()方法替换 * ? + / | 等字符的时候会报以下异常 Dangling meta character '*' near in ...

  5. shell的循环嵌套语法

    测试shell的循环嵌套语法 [root@localhost test]# vi Xunhuanqiantao.sh #!/bin/bash #程序功能描述: # 测试循环嵌套 #作者:孤舟点点 #版 ...

  6. swift中的闭包总结

    闭包是功能性自包含模块,可以在代码中被传递和使用. Swift 中的闭包与 Objective-C中的 blocks 以及其他一些编程语言中的 lambdas 比较相似. 闭包的基本语法 闭包表达式语 ...

  7. clearstatcache清除文件状态缓存

    当使用下列任何函数时stat(),lstat(),file_exists(),is_writable(),is_readable(),is_executable(),is_file(),is_dir( ...

  8. 万达乐园VS阿里帝国 谁将是未来娱乐产业的龙头?

    国内实体行业大佬王健林和互联网行业巨头马云,这次又不约而同地想到一块去了.从王健林叫板迪士尼大搞借势营销,到最近马云成立大文娱工作领导小组,明显的趋势表明娱乐越来越成为各界大佬们未来掘金的新战场.只不 ...

  9. 《ASP.NET Core 高性能系列》Span<T>和Memory<T>

    一.Span<T>概述 原文:Provides a type- and memory-safe representation of a contiguous region of arbit ...

  10. C++走向远洋——61(项目一、排序函数模板)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...