解决DropDownList总是选中第一项的方法
在网页开发的过程中,在页面中使用了一个DropDownList服务器控件,发现了一个很奇怪的问题,不论在页面中选中哪一项,在后台获取到的值总是第一项的值,看了好久也没有发现问题出在哪里,DropDownList控件在开发中已经使用了无数遍了,对照了其他代码都是一样的!
经过了几分钟之后,实在是看不出问题在哪里只好到网上查找答案,网上果然有不少人遇到“一样”的问题——DropDownList总是选中第一项。网上的解决方法都是说在DropDownList绑定时要在Page_Load事件要使用if(!IsPostBack),可是我是这样绑定的,在网上还是没有找到解决的方法。
后来,自己静静地左思右想,是不是因为自己在绑定DropDownList的时候,只给Text赋值,而没有给Value赋值导致的呢?接着我就尝试把每一项的Value赋值,果然没有这样的现象了!
现在总结DropDownList控件总是选中第一项的两种原因。
情况一,请看下面的代码:
客户端代码:
<asp:DropDownListID="ddl1"runat="server"> </asp:DropDownList>
服务端代码:
protectedvoidPage_Load(objectsender,EventArgse) { BindDropDownList(); } privatevoidBindDropDownList() { ddl1.Items.Clear();//每次绑定前,先清除所有项 for(inti=1;i<=3;i++) { ListItemitem1=newListItem(); item1.Text="第"+i.ToString()+"项"; item1.Value="第"+i.ToString()+"项"; ddl1.Items.Add(item1); } }
上面代码案例,也就是网上说的总是选中第一项(选择不能改变选项),绑定方法写在if(!IsPostBack)里就可以解决了,代码如下:
protectedvoidPage_Load(objectsender,EventArgse) { if(!IsPostBack) { BindDropDownList(); } }
情况二,即是笔者遇到的,请看下面的代码:
客户端代码:
<asp:DropDownListID="ddl1"runat="server"> </asp:DropDownList> <asp:ButtonID="btnGet"runat="server"Text="获取"onclick="btnGet_Click"/>
服务端代码:
protectedvoidPage_Load(objectsender,EventArgse) { if(!IsPostBack) { BindDropDownList(); } } privatevoidBindDropDownList() { ddl1.Items.Clear();//每次绑定前,先清除所有项 for(inti=1;i<=3;i++) { ListItemitem1=newListItem(); item1.Text="第"+i.ToString()+"项"; item1.Value=""; ddl1.Items.Add(item1); } } protectedvoidbtnGet_Click(objectsender,EventArgse) { stringstr=ddl1.SelectedItem.Text; Page.ClientScript.RegisterStartupScript(this.GetType(),"alert","<script>alert('"+str+"');</script>"); }
注意item1.Value这个地方,是没有赋值的,然而导致获取Text的值错乱了,只要给Value赋上值就没有问题了!
以上就是关于网上大多数人遇到“一样”的问题——DropDownList总是选中第一项的解决办法,希望对大家的学习有所帮助。