• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

ASP.NET多彩下拉框开发实例

asp 搞代码 4年前 (2022-01-03) 52次浏览 已收录 0个评论

有人曾经提出开发一个根据不同选择而显示不同颜色的管理工具,本文主要就是演示如何读取系统颜色并在下拉框中的每个条目中显示对应的颜色,需要的朋友可以参考下

本文主要是演示如何读取系统颜色并在下拉框中的每个条目中显示对应的颜色,该源码主要展示以下内容:

   1、如何获得System.Drawing.KnownColor颜色控件的列表枚举

   2、如何排除系统环境颜色,如“Active Border”

   3、如何分配颜色到下拉框的每个条目  

代码详解:

   命名下拉框为ddlMultiColor 来显示颜色名称及颜色,用

标签显示右侧矩形结果,Aspx代码如下

 <table> <tr> <td>  </td><td> <div id="msgColor"> </div></td></tr></table>

 在cs文件中我们需要引用以下命名空间:

 using System; using System.Web; using System.Reflection; using System.Drawing; using System.Collections.Generic;

我们先看一下Page_Load事件,在Page_Load中我们对选中的下拉列表进行处理显示

 protected void Page_Load(object sender, EventArgs e) { if (Page.IsPostBack == false) { populateDdlMultiColor(); //51aspx.com colorManipulation(); } } 

  现在让我们来看一下populateDdlMultiColor() 函数

 private void populateDdlMultiColor() { ddlMultiColor.DataSource = finalColorList(); ddlMultiColor.DataBind(); // } finalColorList()方法 private List finalColorList() { string[] allColors = Enum.GetNames(typeof(System.Drawing.KnownColor)); string[] systemEnvironmentColors = new string[( typeof(System.Drawing.SystemColors)).GetProperties().Length]; int index = 0; foreach (MemberInfo member in ( typeof(System.Drawing.SystemColors)).GetProperties()) { systemEnvironmentColors[index ++] = member.Name; } List finalColorList = new List(); foreach (string color in allColors) { if (Array.IndexOf(systemEnvironmentColors, color) <0) { finalColorList.Add(color); } } return finalColorList; } 

System.Drawing.KnownColor是Asp.net系统本身自带颜色,我已经通过枚举列出了这些颜色并通过 finalColorList()函授进行绑定。为了实现该功能,我使用了最基本的枚举特征之一:Enum.GetNames() 共享方法,该方法对枚举内容进行检测并输出结果为字符串序列,该字符串中每个值都对应枚举中的每个结果。

 然而,该方法还是有些问题的。按照上面的思路,枚举金额过中会包括系统环境颜色,比如“Active Border(注:活动边框)”,为了解决该问题,我扩展了系统环境颜色。我用了System.Reflection.MemberInfo类。

 这里我用System.Drawing.SystemColors属性填充systemEnvironmentColors ,然后创建一个名称为finalColorList 的图形列表,在finalColorList 中我只调用已知颜色,但是不在系统环境颜色中。然后把finalColorList绑定到ddlMultiColor中。至此,我们已经有了一个包括全部颜色名称的下拉框,下面让我们来操作一下:

 private void colorManipulation() { int row; for (row = 0; row <ddlMultiColor.Items.Count - 1; row++) { ddlMultiColor.Items[row].Attributes.Add("style", "background-color:" + ddlMultiColor.Items[row].Value); } ddlMultiColor.BackColor = Color.FromName(ddlMultiColor.SelectedItem.Text);//liudao翻译 }

下拉框中的每一行背景颜色的Style]属性都与该行显示的颜色名称对应的。在OnSelectedIndexChanged 事件中下拉框中被选中的行通过下面的函数结合

标签进行高亮显示,同时右侧的矩形颜色也随之变化。

 protected void ddlMultiColor_OnSelectedI<b style="color:transparent">来源gao@dai!ma.com搞$代^码网</b>ndexChanged(object sender, EventArgs e) { ddlMultiColor.BackColor = Color.FromName(ddlMultiColor.SelectedItem.Text); colorManipulation(); ddlMultiColor.Items.FindByValue(ddlMultiColor.SelectedValue).Selected = true; msgColor.Attributes.Add("style", "background:" + ddlMultiColor.SelectedItem.Value + ";width:30px;height:25px;"); }

至此,我们学会了如果获取System.Drawing并排出系统环境颜色,并绑定颜色名称到下拉列表。

以上就是ASP.NET多彩下拉框开发实例的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:ASP.NET多彩下拉框开发实例

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址