checkboxlist是服务器控件,绑定数据容易,服务器端获取选中值也容易。但是生成的静态页面居然没有listitem的value值,所以默认情况下用js在页面中是取不到listitem的值的。至于为什么不显示value值,我也不清楚,本篇给出一个用jquery获取checkboxlist值的方法。
先看看原始的页面html代码:
下面我们绑定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代码如下:
基于jquery的一个震动效果
使用css的overflow属性改变缩略图大小
可以看出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代码如下:
基于jquery的一个震动效果
使用css的overflow属性改变缩略图大小
从上边可以看出,多了一个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值的方法,不知道大家有没有真正理解,希望这篇文章能够帮到大家。