ListBox 绑定多个选项为选中

本演示是让你知道如何多个值绑定至ListBox显示为选中。ListBox在default情况之下,SelectionMode为Single,因此为了多选,而需要设置此属性为Multiple。在实现之前,可以先看到Insus.NET所实现最终效果,gif动画,无声音:

 

 

 .aspx:

  < asp:TextBox  ID ="TextBox1"  runat ="server"  Width ="300" ></ asp:TextBox >
         < br  />
         < asp:Button  ID ="Button1"  runat ="server"  Text ="Binding"  OnClick ="Button1_Click"   />
         < br  />
         < br  />
         < asp:ListBox  ID ="ListBox1"  runat ="server"  Height ="100"  SelectionMode ="Multiple"   ></ asp:ListBox >

 

.aspx.cs中,首先是为ListBox准备数据,然后对ListBox控件进行数据绑定:

ExpandedBlockStart.gif View Code
  protected  void Page_Load( object sender, EventArgs e)
    {
         if (!IsPostBack)
        {
            Data_Binding();
        }

    }

     private  void Data_Binding()
    {
         this.ListBox1.DataSource = Site();
         this.ListBox1.DataTextField =  " key ";
         this.ListBox1.DataValueField =  " value ";
         this.ListBox1.DataBind();
    }

     private Dictionary< stringstring> Site()
    {
        Dictionary< stringstring> site =  new Dictionary< stringstring>();
        site.Add( " Insus.NET cnblogs "" http://insus.cnblogs.com ");
        site.Add( " Microsoft "" http://www.microsoft.com ");
        site.Add( " Google "" http://www.google.com ");
        site.Add( " Yahoo "" http://www.yahoo.com.cn ");
        site.Add( " Ifeng "" http://www.ifeng.com ");
        site.Add( " sina "" http://www.sina.com.cn ");
        site.Add( " 163 "" http://www.163.com ");
        site.Add( " QQ "" http://www.qq.com ");
         return site;
    }

 

为了让TextBox的字符串以";"分割为多个值,引用了命名空间

using System.Collections;

 

接下来,是写button的click事件,代码相当简单,Insus.NET在此不作过多注释:

ExpandedBlockStart.gif View Code
protected  void Button1_Click( object sender, EventArgs e)
    {
         string[] s =  this.TextBox1.Text.Split( ' ; ');
        
         foreach (ListItem li  in  this.ListBox1.Items)
        {                     
            li.Selected = ((IList)s).Contains(li.Text) ?  true :  false;           
        }
    }

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值