最近很是鬱悶,一個可輸入的下拉框搞了我好幾天,開始的時候在網上找到一個伺服器控制項,用了一下,發現滿足不了自己的需求。於是乎花了幾個小時改了改,終於成形。這個控制項和別人不同有以下兩點:
1,一般的dropdownlist都會預設選中第一條,這樣的話,在選擇第一條的時候就沒有事件,而往往這時候我們需要觸發ongchange事件,於是我在它的foucus事件中強行改變它的selectedIndex。
2,輸入的內容如果和下拉框中的某項相同時,會自動選中下拉框中那一條。
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;
using System.Collections;
namespace ExtendWebControls
{
[ToolboxData("<{0}:DropDownListExtend runat=\"server\" />")]
public class DropDownListExtend : System.Web.UI.WebControls.TextBox
{
private Hashtable _values;
private DropDownList _DropDownList;
public DropDownListExtend()
{
_values = new Hashtable();
_DropDownList = new DropDownList();
}
public Hashtable Values
{
get{return _values;}
set{_values = value;}
}
protected override void Render(HtmlTextWriter output)
{
int iWidth = Convert.ToInt32(base.Width.Value);
if(iWidth == 0)
{
iWidth = 102;
base.Width = Unit.Parse("102px");
}
int sWidth = iWidth + 16;
int spanWidth = sWidth - 18;
output.Write("<div style=\"POSITION:relative\">");
output.Write("<span style=\"MARGIN-LEFT:" + spanWidth.ToString() + "px;OVERFLOW:hidden;WIDTH:18px\">");
_DropDownList.Width = Unit.Parse(sWidth.ToString() + "px");
_DropDownList.Style.Add("MARGIN-LEFT", "-" + spanWidth.ToString() + "px");
_DropDownList.ID = base.ID + "_Select";
_DropDownList.Attributes.Add("onchange", "this.parentNode.nextSibling.value=this.value");
_DropDownList.Attributes.Add("onfocus", ""+this.getFocusScript()+"");
if(_values.Count > 0)
{
foreach(string key in _values.Keys)
{
ListItem item = new ListItem();
item.Value = key;
item.Text = _values[key].ToString();
_DropDownList.Items.Add(item);
}
}
_DropDownList.RenderControl(output);
output.Write("</span>");
base.Style.Clear();
base.Width = Unit.Parse(iWidth.ToString() + "px");
base.Style.Add("left", "0px");
base.Style.Add("POSITION", "absolute");
base.Render(output);
output.Write("</div>");
}
private string getFocusScript()
{
string strScript = "\n";
strScript += "var isExist = -2;\n";
strScript += "var obj = event.srcElement;\n";
strScript += "var str = this.parentNode.nextSibling.value;\n";
strScript += "var ary = obj.options;\n";
strScript += "for(var i=0;i<ary.length;i++){\n";
strScript += " if(str == ary[i].text){\n";
strScript += " isExist = i;\n";
strScript += " break;\n";
strScript += " }\n";
strScript += "}\n";
strScript += "if(isExist != -2){\n";
strScript += " obj.selectedIndex = isExist;\n";
strScript += "}\n";
strScript += "else{\n";
strScript += " obj.selectedIndex = -1;\n";
strScript += "}\n";
return strScript;
}
}
}