• 欢迎访问开心洋葱网站,在线教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站,欢迎加入开心洋葱 QQ群
  • 为方便开心洋葱网用户,开心洋葱官网已经开启复制功能!
  • 欢迎访问开心洋葱网站,手机也能访问哦~欢迎加入开心洋葱多维思维学习平台 QQ群
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏开心洋葱吧~~~~~~~~~~~~~!
  • 由于近期流量激增,小站的ECS没能经的起亲们的访问,本站依然没有盈利,如果各位看如果觉着文字不错,还请看官给小站打个赏~~~~~~~~~~~~~!

ASP.NET MVC DropDownList数据绑定及使用代码范例

JavaScript 水墨上仙 1422次浏览

DropDownList 控件用于创建下拉列表。DropDownList 控件中的每个可选项都是由 ListItem 元素定义的!该控件支持数据绑定

一:DropDownList&nbsp
1.1&nbspDropDownList绑定数据&nbsp
1.1.1&nbspDropDownList&nbsp固定绑定&nbsp
这种方式适合那些已经固定的数据绑定到DropDownList上。&nbsp

<asp:DropDownList runat="server" ID="ddlArea" Width="120px" > 
<asp:Listitem value="0">选择性别</asp:Listitem> 
<asp:Listitem value="1">男</asp:Listitem> 
<asp:Listitem value="2">女</asp:Listitem> 
</asp:DropDownList> 

1.1.2&nbspDropDownList&nbsp动态绑定&nbsp
前台:&nbsp
后台:两种方法:(注意,每次绑定都要清除一下原来的记录,例:ddlArea.Items.Clear();)&nbsp
第一种:&nbsp

SqlConnection conn = new SqlConnection("server=.;uid=sa;database=pubs"); 
SqlDataAdapter dap = new SqlDataAdapter("select * from jobs", conn); 
DataTable dt = new DataTable(); 
dap.Fill(dt); 
DropDownList1.Items.Clear(); 
DropDownList1.DataSource = dt; 
DropDownList1.DataTextField = "job_desc"; 
DropDownList1.DataValueField = "job_id"; 
DropDownList1.DataBind(); 
DropDownList1.Items.Insert(0, new ListItem("选择数据", "随机绑定"));//插入默认项,此举必须放到数据绑定之后效果: 

第二种:&nbsp

SqlConnection conn = new SqlConnection("server=.;uid=sa;database=pubs"); 
SqlDataAdapter dap = new SqlDataAdapter("select * from jobs", conn); 
DataTable dt = new DataTable(); 
dap.Fill(dt); 
if (dt.Rows.Count != 0) 
{ 
DropDownList1.Items.Clear(); 
for (int i = 0; i < dt.Rows.Count; i++) 
{ 
DropDownList1.Items.Add(new ListItem(dt.Rows[i]["显示值"].ToString(), dt.Rows[i]["usbkey"].ToString())); 
} 
DropDownList1.Items.Insert(0, "选择网吧"); 
DropDownList1.Items[0].Value = "0"; 或 
// DropDownList1.Items.Insert(0, new ListItem("选择数据", "随机绑定"));//插入默认项,此举必须放到数据绑定之 
} 
else 
{ 
DropDownList1.Items.Insert(0, "无网吧记录"); 
DropDownList1.Items[0].Value = "0"; 
} 

二:DropDownList1的取值问题:&nbsp
2.1&nbsp取DropDownList1的索引值,也就是选择&nbspvalue&nbsp值&nbsp取1&nbsp
.net中&nbspDropDownList1.SelectedValue.ToString()&nbsp
javascirpt&nbspvar&nbspddl1=document.getElementByIdx_x(“DropDownList1”).selectedIndex;&nbsp
2.2&nbsp取DropDownList1的选项,也就是选择item值&nbsp取&nbsp男&nbsp
.net&nbsp中DropDownList1.SelectedItem.ToString();&nbsp
javascript&nbspdocument.getElementByIdx_x(“DropDownList1”).options[document.getElement(“selectID”).selectedIndex].value&nbsp
三:DropDownList1事件问题:&nbsp
重点:使用OnTextChanged,OnSelectedIndexChanged事件时,必须设置&nbsp

<asp:DropDownList runat="server" OnTextChanged="DropDownList1_TextChanged"OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged1"> 

OnTextChanged,OnSelectedIndexChanged这两个事件具体有什么区别,我也没测试出来,只知道OnSelectedIndexChanged这个事件要比OnTextChanged执行的早,也就是如果这两个事件都存在,会首先执行OnSelectedIndexChanged这个事件,然后才执行OnTextChanged.&nbsp
四:如何避免DropDownList下拉框中的值重复添加?&nbsp
AppendDataBoundItems是否填加重复值。真为添加,假为不填加&nbsp
原因:DropDownList控件AppendDataBoundItems属性设置为”True”了的,改为False即可。&nbsp
例如:如果专业后的DropDownList控件AppendDataBoundItems属性设置为”True”,那么选择院系后专业里的值会不断添加。&nbsp
五:区别&nbsp

depart_ddl.Items.Insert(0,new ListItem("不选该项","0")); 这是在首项添加数据。 
Items.Add是在最后添加 
DropDownList1.Items.Add(new ListItem("Text","value")); 是在最后添加 
DropDownList1.Items.Insert(Index,new ListItem("Text","value"));这是在首项添加数据。 

六:从数据库中读取数据,并绑定到DropDownList中&nbsp

if (ds.Tables[0].Rows[0]["State"].ToString ()=="True") 
{ 
DropDownListState.Items.FindByValue("1").Selected =true; 
} 
else 
{ 
DropDownListState.Items.FindByValue("0").Selected =true; 
} 


开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明ASP.NET MVC DropDownList数据绑定及使用代码范例
喜欢 (0)
加载中……