DropDownList(ListBox)控件既强大又好用。为了让它更强大、更好用,我们来写一个继承自
DropDownList(ListBox)的控件。
[源码下载]
扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)
作者:
webabcd
介绍
扩展DropDownList控件和ListBox控件:
通过
DropDownList控件和ListBox控件的.Items.Add(ListItem item)方法,来为其添加optgroup标签,从而实现分组功能
使用方法
1、设置属性:
OptionGroupValue - 用于添加DropDownList(ListBox)控件的分组项的ListItem的Value值(默认为optgroup)
2、使用DropDownList(ListBox)控件的.Items.Add(ListItem item)方法:
OptionGroupValue为默认值时:SmartDropDownList.Items.Add(new ListItem("中国", "optgroup"));
图示
data:image/s3,"s3://crabby-images/bd232/bd23296c694379851bb9968358e84f51b9f324fb" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
关键代码(以DropDownList为例)
SmartDropDownList.cs
using
System;
using
System.Collections.Generic;
using
System.Text;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
using
System.Web.UI.WebControls;
using
System.Web.UI;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
[assembly: System.Web.UI.WebResource(
"
YYControls.SmartDropDownList.Resources.Icon.bmp
"
,
"
image/bmp
"
)]
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
namespace
YYControls
data:image/s3,"s3://crabby-images/53857/53857fde5c98200cc2d0515169530ea23028cc6b" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// SmartDropDownList类,继承自DropDownList
/// </summary>
[ToolboxData(@"<{0}:SmartDropDownList runat='server'></{0}:SmartDropDownList>")]
[System.Drawing.ToolboxBitmap(typeof(YYControls.Resources.Icon), "SmartDropDownList.bmp")]
public partial class SmartDropDownList : DropDownList
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 构造函数
/// </summary>
public SmartDropDownList()
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 将控件的内容呈现到指定的编写器中
/// </summary>
/// <param name="writer">writer</param>
protected override void RenderContents(HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 呈现Option或OptionGroup
OptionGroupRenderContents(writer);
}
}
}
Property.cs
using
System;
using
System.Collections.Generic;
using
System.Text;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
using
System.ComponentModel;
using
System.Web.UI;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
namespace
YYControls
data:image/s3,"s3://crabby-images/53857/53857fde5c98200cc2d0515169530ea23028cc6b" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// SmartDropDownList类的属性部分
/// </summary>
public partial class SmartDropDownList
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 用于添加SmartDropDownList的分组项的ListItem的Value值
/// </summary>
[
Browsable(true),
Description("用于添加DropDownList的分组项的ListItem的Value值"),
Category("扩展")
]
public virtual string OptionGroupValue
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
get
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
string s = (string)ViewState["OptionGroupValue"];
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
return (s == null) ? "optgroup" : s;
}
set
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
ViewState["OptionGroupValue"] = value;
}
}
}
}
OptionGroup.cs
using
System;
using
System.Collections.Generic;
using
System.Text;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
using
System.Data;
using
System.Web.UI.WebControls;
using
System.Web.UI;
using
System.Web;
data:image/s3,"s3://crabby-images/6da9e/6da9e24ab5d8557950df0ee17348796707d3a780" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
namespace
YYControls
data:image/s3,"s3://crabby-images/53857/53857fde5c98200cc2d0515169530ea23028cc6b" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// SmartDropDownList类的属性部分
/// </summary>
public partial class SmartDropDownList
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 呈现Option或OptionGroup
/// </summary>
/// <param name="writer">writer</param>
private void OptionGroupRenderContents(HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 是否需要呈现OptionGroup的EndTag
bool writerEndTag = false;
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
foreach (ListItem li in this.Items)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 如果没有optgroup属性则呈现Option
if (li.Value != this.OptionGroupValue)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 呈现Option
RenderListItem(li, writer);
}
// 如果有optgroup属性则呈现OptionGroup
else
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
if (writerEndTag)
// 呈现OptionGroup的EndTag
OptionGroupEndTag(writer);
else
writerEndTag = true;
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
// 呈现OptionGroup的BeginTag
OptionGroupBeginTag(li, writer);
}
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
if (writerEndTag)
// 呈现OptionGroup的EndTag
OptionGroupEndTag(writer);
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 呈现OptionGroup的BeginTag
/// </summary>
/// <param name="li">OptionGroup数据项</param>
/// <param name="writer">writer</param>
private void OptionGroupBeginTag(ListItem li, HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
writer.WriteBeginTag("optgroup");
// 写入OptionGroup的label
writer.WriteAttribute("label", li.Text);
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
foreach (string key in li.Attributes.Keys)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 写入OptionGroup的其它属性
writer.WriteAttribute(key, li.Attributes[key]);
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
writer.Write(HtmlTextWriter.TagRightChar);
writer.WriteLine();
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 呈现OptionGroup的EndTag
/// </summary>
/// <param name="writer">writer</param>
private void OptionGroupEndTag(HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
writer.WriteEndTag("optgroup");
writer.WriteLine();
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
/**//// <summary>
/// 呈现Option
/// </summary>
/// <param name="li">Option数据项</param>
/// <param name="writer">writer</param>
private void RenderListItem(ListItem li, HtmlTextWriter writer)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
writer.WriteBeginTag("option");
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
// 写入Option的Value
writer.WriteAttribute("value", li.Value, true);
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
if (li.Selected)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 如果该Option被选中则写入selected
writer.WriteAttribute("selected", "selected", false);
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
foreach (string key in li.Attributes.Keys)
data:image/s3,"s3://crabby-images/6fea9/6fea96cbe3985a57b9499e01b9a80b80a7896dff" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
{
// 写入Option的其它属性
writer.WriteAttribute(key, li.Attributes[key]);
}
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
writer.Write(HtmlTextWriter.TagRightChar);
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
// 写入Option的Text
HttpUtility.HtmlEncode(li.Text, writer);
data:image/s3,"s3://crabby-images/bc68a/bc68a723ffc8d86946ffe34610bd1600d9d39986" alt="扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签) 扩展DropDownList控件和ListBox控件(1) - 支持分组功能(optgroup标签)"
writer.WriteEndTag("option");
writer.WriteLine();
}
}
}
OK
[源码下载]