您的位置:首页 > 编程语言 > ASP

Asp.net服务器端控件CheckBoxList的使用心得

2009-01-07 10:25 459 查看
1.用JavaScript获得Asp.net服务器端控件CheckBoxList选中得值

Asp.net服务器端控件CheckBoxList在客户端没有生成value值,所以就想在客户端通过JS获得选中项就很麻烦了。
迫于无奈,只能写了以下的代码。比较通用,适合于CheckBoxList的属性RepeatLayout为Flow和Table,属性RepeatDirection为Horizontal和Vertical
objID为服务器端控件在客户端生成的ID

通用版本(不依赖任何类库)
function GetCheckBoxListValue(objID)
{
var v = new Array();
var CheckBoxList = document.getElementById(objID);
if(CheckBoxList.tagName == "TABLE")
{
for(i=0;i<CheckBoxList.rows.length;i++)
for(j=0;j<CheckBoxList.rows[i].cells.length;j++)
if(CheckBoxList.rows[i].cells[j].childNodes[0])
if(CheckBoxList.rows[i].cells[j].childNodes[0].checked==true)
v.push(CheckBoxList.rows[i].cells[j].childNodes[1].innerText);
}
if(CheckBoxList.tagName == "SPAN")
{
for(i=0;i<CheckBoxList.childNodes.length;i++)
if(CheckBoxList.childNodes[i].tagName == "INPUT")
if(CheckBoxList.childNodes[i].checked==true)
{
i++;
v.push(CheckBoxList.childNodes[i].innerText);
}
}
return v;
}

Asp.net Ajax版本(依赖Asp.net Ajax类库支持)

function GetCheckBoxListValue(objID)
{
var v = new Array();
var CheckBoxList = $get(objID);
if(CheckBoxList.tagName == "TABLE")
{
for(i=0;i<CheckBoxList.rows.length;i++)
for(j=0;j<CheckBoxList.rows[i].cells.length;j++)
if(CheckBoxList.rows[i].cells[j].childNodes[0])
if(CheckBoxList.rows[i].cells[j].childNodes[0].checked==true)
Array.add(v,CheckBoxList.rows[i].cells[j].childNodes[1].innerText);
}
if(CheckBoxList.tagName == "SPAN")
{
for(i=0;i<CheckBoxList.childNodes.length;i++)
if(CheckBoxList.childNodes[i].tagName == "INPUT")
if(CheckBoxList.childNodes[i].checked==true)
{
i++;
Array.add(v,CheckBoxList.childNodes[i].innerText);
}
}
return v;
}

2.判断CheckBoxList中SelectedIndexChanged事件是哪个checkbox引发的

private static bool[] arrtmp;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if(!IsPostBack)
{
arrtmp=new bool[CheckBoxList1.Items.Count];
for(int i=0;i <=CheckBoxList1.Items.Count-1;i++)
{
arrtmp[i]=CheckBoxList1.Items[i].Selected;
}
}
}

//判断当前触发的checkbox项的id和是否选中
private void CheckBoxList1_SelectedIndexChanged(object sender, System.EventArgs e)
{
int clicknum;
clicknum=-1;
for(int i=0;i <= CheckBoxList1.Items.Count-1;i++)
{
if(arrtmp[i]!=CheckBoxList1.Items[i].Selected)
{
arrtmp[i] =CheckBoxList1.Items[i].Selected;
clicknum=i;
break;
}
}
if(clicknum>=0)
{
TextBox1.Text=CheckBoxList1.Items[clicknum].ToString();
}
}

3.得到当前所有CheckBoxList选择的项

protected void CheckBoxList1_SelectedIndexChanged(object sender, EventArgs e)
{
//得到当前所有选择的项
string Groupid = "";
foreach (ListItem li in ((CheckBoxList)sender).Items)
{
if (li.Selected)
{
if (Groupid == "")
{
Groupid = Groupid + li.Value;
}
else
{
Groupid = Groupid + "," + li.Value;
}
}
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐