手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery获取checkboxlist的value值的方法
jQuery获取checkboxlist的value值的方法
摘要:CheckboxList是服务器控件,绑定数据容易,服务器端获取选中值也容易。但是生成的静态页面居然没有ListItem的Value值,所以...

CheckboxList是服务器控件,绑定数据容易,服务器端获取选中值也容易。但是生成的静态页面居然没有ListItem的Value值,所以默认情况下用js在页面中是取不到ListItem的值的。至于为什么不显示value值,我也不清楚,本篇给出一个用jQuery获取checkboxlist值的方法。

先看看原始的页面html代码:

<asp:CheckBoxList runat="server" ID="listTest"> </asp:CheckBoxList> <input type="button" id="btnShow" value="显示选中值" />

下面我们绑定checkboxlist,代码如下:

if (dt != null && dt.Rows.Count > 0) { foreach (DataRow dr in dt.Rows) { //分别为text值、value值 listTest.Items.Add(new ListItem(dr["Title"].ToString(), dr["ID"].ToString())); } }

页面中生成的html代码如下:

<table id="listTest" border="0"> <tr> <td> <input id="listTest_0" type="checkbox" name="listTest$0" /> <label for="listTest_0">基于jQuery的一个震动效果</label> </td> </tr> <tr> <td><input id="listTest_1" type="checkbox" name="listTest$1" /> <label for="listTest_1">使用css的overflow属性改变缩略图大小</label> </td> </tr> </table>

可以看出checkboxlist转换为一个表格的形式,并且其中没有value值。label中的值,即为text值。当点击它时,也可以选中checkbox,这里在选checkbox时提高了用户体验。

下面进入我们的处理过程,首先,在绑定checkboxlist时,为ListItem每个对象添加一个alt属性,值保存对应的value值,代码如下:

if (dt != null && dt.Rows.Count > 0) { foreach (DataRow dr in dt.Rows) { //分别为text值、value值 listTest.Items.Add(new ListItem(dr["Title"].ToString(), dr["ID"].ToString())); } //为ListItem对象添加alt属性,值保存value值 foreach (ListItem li in listTest.Items) { li.Attributes.Add("alt", li.Value); } }

现在,生成的html代码如下:

<table id="Table1" border="0"> <tr> <td> <span alt="400"><input id="listTest_0" type="checkbox" name="listTest$0" /> <label for="listTest_0">基于jQuery的一个震动效果</label></span> </td> </tr> <tr> <td><span alt="398"><input id="listTest_1" type="checkbox" name="listTest$1" /> <label for="listTest_1">使用css的overflow属性改变缩略图大小</label></span> </td> </tr> </table>

从上边可以看出,多了一个span标签,里边alt的值即为我们需要的value值。使用下边的jQuery代码即可获得:

$(document).ready(function() { $("#btnShow").click(function() { var valuelist = ""; //保存checkbox选中值 //遍历name以listTest开头的checkbox $("input[name^='listTest']").each(function() { if (this.checked) { //$(this):当前checkbox对象; //$(this).parent("span"):checkbox父级span对象 valuelist += $(this).parent("span").attr("alt") + ","; } }); if (valuelist.length > 0) { //得到选中的checkbox值序列,结果为400,398 valuelist = valuelist.substring(0, valuelist.length - 1); } }); });

以上就是jQuery获取checkboxlist的value值的方法,不知道大家有没有真正理解,希望这篇文章能够帮到大家。

【jQuery获取checkboxlist的value值的方法】相关文章:

jquery控制表单输入框显示默认值的方法

jQuery实现首页图片淡入淡出效果的方法

jQuery取消ajax请求的方法

jquery判断至少有一个checkbox被选中的方法

jQuery实现返回顶部效果的方法

JQuery勾选指定name的复选框集合并显示的方法

jQuery子窗体取得父窗体元素的方法

JQuery自动触发事件的方法

jQuery实现html表格动态添加新行的方法

JQuery给网页更换皮肤的方法

精品推荐
分类导航