服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - ASP.NET教程 - asp.net中关于dropdwonlist无法获得值问题

asp.net中关于dropdwonlist无法获得值问题

2019-09-23 10:36asp.net教程网 ASP.NET教程

用dropdwonlist绑定了一个数据源做选择,但是当提交时,用控件属性无法获得相应的值,打印出来每次都是显示的第一个值

前端控件: 

复制代码代码如下:


<label>发布栏目:<asp:DropDownList ID="sectionDropDownList" runat="server"></asp:DropDownList></label 


数据绑定: 

复制代码代码如下:


SourceDb DropDwonListData = new SourceDb(); 
string DropDwonSelect = "SELECT * FROM [Section]"; 
sectionDropDownList.DataSource = DropDwonListData.DatasetDb(DropDwonSelect).Tables[0].DefaultView; 
sectionDropDownList.DataTextField = "name"; 
sectionDropDownList.DataValueField = "code"; 
sectionDropDownList.DataBind(); 


Button事件: 

复制代码代码如下:


string newsTitle = sectionDropDownList.SelectedValue; 
Response.Write(newsTitle); 


问题分析: 

因为在page_load中每次都绑定了数据源,而去调用Button事件时,实际是每次都刷新了页面的,于是每次在打印出来前都是初始化的值,于是每次都是输出的的一个值。 

问题解决: 

判断是否是页面回调。 

前端控件: 

复制代码代码如下:


<label>发布栏目:<asp:DropDownList ID="sectionDropDownList" runat="server"></asp:DropDownList></label 


数据绑定: 

复制代码代码如下:


if(!IsPostBack){ 
  SourceDb DropDwonListData 
= new SourceDb(); 
  string DropDwonSelect = "SELECT * FROM [Section]"; 
  sectionDropDownList.DataSource = DropDwonListData.DatasetDb(DropDwonSelect).Tables[0].DefaultView; 
  sectionDropDownList.DataTextField = "name"; 
  sectionDropDownList.DataValueField = "code"; 
  sectionDropDownList.DataBind(); 



Button事件: 

复制代码代码如下:


string newsTitle = sectionDropDownList.SelectedValue; 
Response.Write(newsTitle); 

延伸 · 阅读

精彩推荐