ASP.NET多彩下拉框開發(fā)實(shí)例
本文主要是演示如何讀取系統(tǒng)顏色并在下拉框中的每個(gè)條目中顯示對應(yīng)的顏色,該源碼主要展示以下內(nèi)容:
1、如何獲得System.Drawing.KnownColor顏色控件的列表枚舉
2、如何排除系統(tǒng)環(huán)境顏色,如“Active Border”
3、如何分配顏色到下拉框的每個(gè)條目
代碼詳解:
命名下拉框?yàn)閐dlMultiColor 來顯示顏色名稱及顏色,用<div>標(biāo)簽顯示右側(cè)矩形結(jié)果,Aspx代碼如下
<table> <tr> <td> <asp:DropDownList ID ="ddlMultiColor" OnSelectedIndexChanged="ddlMultiColor_OnSelectedIndexChanged" runat="server" AutoPostBack="true"> </asp:DropDownList> </td> <td> <div id="msgColor" runat="server"> </div> </td> </tr> </table>
在cs文件中我們需要引用以下命名空間:
using System; using System.Web; using System.Reflection; using System.Drawing; using System.Collections.Generic;
我們先看一下Page_Load事件,在Page_Load中我們對選中的下拉列表進(jìn)行處理顯示
protected void Page_Load(object sender, EventArgs e)
{
if (Page.IsPostBack == false)
{
populateDdlMultiColor(); //51aspx.com
colorManipulation();
}
}
現(xiàn)在讓我們來看一下populateDdlMultiColor() 函數(shù)
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系統(tǒng)本身自帶顏色,我已經(jīng)通過枚舉列出了這些顏色并通過 finalColorList()函授進(jìn)行綁定。為了實(shí)現(xiàn)該功能,我使用了最基本的枚舉特征之一:Enum.GetNames() 共享方法,該方法對枚舉內(nèi)容進(jìn)行檢測并輸出結(jié)果為字符串序列,該字符串中每個(gè)值都對應(yīng)枚舉中的每個(gè)結(jié)果。
然而,該方法還是有些問題的。按照上面的思路,枚舉金額過中會(huì)包括系統(tǒng)環(huán)境顏色,比如“Active Border(注:活動(dòng)邊框)”,為了解決該問題,我擴(kuò)展了系統(tǒng)環(huán)境顏色。我用了System.Reflection.MemberInfo類。
這里我用System.Drawing.SystemColors屬性填充systemEnvironmentColors ,然后創(chuàng)建一個(gè)名稱為finalColorList 的圖形列表,在finalColorList 中我只調(diào)用已知顏色,但是不在系統(tǒng)環(huán)境顏色中。然后把finalColorList綁定到ddlMultiColor中。至此,我們已經(jīng)有了一個(gè)包括全部顏色名稱的下拉框,下面讓我們來操作一下:
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]屬性都與該行顯示的顏色名稱對應(yīng)的。在OnSelectedIndexChanged 事件中下拉框中被選中的行通過下面的函數(shù)結(jié)合<div>標(biāo)簽進(jìn)行高亮顯示,同時(shí)右側(cè)的矩形顏色也隨之變化。
protected void ddlMultiColor_OnSelectedIndexChanged(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;");
}
至此,我們學(xué)會(huì)了如果獲取System.Drawing并排出系統(tǒng)環(huán)境顏色,并綁定顏色名稱到下拉列表。
- ASP.NET?MVC實(shí)現(xiàn)多選下拉框
- 詳解ASP.NET MVC 下拉框的傳值的兩種方式
- ASP .NET 可編輯輸入自動(dòng)匹配的下拉框
- 詳解ASP.NET MVC之下拉框綁定四種方式
- ASP.NET MVC下拉框聯(lián)動(dòng)實(shí)例解析
- ASP.NET中DropDownList下拉框列表控件綁定數(shù)據(jù)的4種方法
- ASP.NET實(shí)現(xiàn)級聯(lián)下拉框效果實(shí)例講解
- asp.net mvc下拉框Html.DropDownList 和DropDownListFor的常用方法
- asp.net中js+jquery添加下拉框值和后臺(tái)獲取示例
- asp.net 實(shí)現(xiàn)下拉框只讀功能
- ASP.NET?MVC下拉框中顯示枚舉項(xiàng)
相關(guān)文章
ASP.net百度主動(dòng)推送功能實(shí)現(xiàn)代碼
百度站長工具的主動(dòng)推送功能,以最為快速的提交方式,推薦您將站點(diǎn)當(dāng)天新產(chǎn)出鏈接立即通過此方式推送給百度,以保證新鏈接可以及時(shí)被百度收錄2020-09-09
asp.net 網(wǎng)頁編碼自動(dòng)識(shí)別代碼
另外一位網(wǎng)友空間/IV提供的代碼,功能同HttpWebRequest獲取網(wǎng)頁源代碼時(shí)自動(dòng)識(shí)別網(wǎng)頁編碼2008-09-09
輕量級ORM框架Dapper應(yīng)用之返回多個(gè)結(jié)果集
這篇文章介紹了使用Dapper返回多個(gè)結(jié)果集的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
ASP.NET實(shí)現(xiàn)圖片以二進(jìn)制的形式存入數(shù)據(jù)庫
這篇文章主要介紹了ASP.NET實(shí)現(xiàn)圖片以二進(jìn)制的形式存入數(shù)據(jù)庫,有一定的學(xué)習(xí)借鑒價(jià)值,需要的朋友可以參考下2014-08-08
如何在ASP.NET Core中使用Session的示例代碼
這篇文章主要介紹了如何在ASP.NET Core中使用Session的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
一個(gè)ASP.Net下的WebShell實(shí)例
一個(gè)ASP.Net下的WebShell,主要完成cmd命令。一般的服務(wù)器設(shè)置,asp.net用戶的權(quán)限都比較高。如果asp的webshell無法執(zhí)行,可能asp.net的可以執(zhí)行。2013-07-07

