当前位置: 移动技术网 > IT编程>开发语言>.net > asp.net动态产生checkbox(数据源为DB或内存集合)

asp.net动态产生checkbox(数据源为DB或内存集合)

2017年12月12日  | 移动技术网IT编程  | 我要评论

辣妈辣妹下载,中直工委,格力凉之静空调

之前在网上看了很多,其实有一些也是大同小异,本人在此小编一下大致解决方案摒弃微软提供的checkboxlist

需求:

1动态产生一组checkbox(数据源为db或内存集合)

2post提交时后台能及时获取

3提交后刷新页面checkbox保持原先选中或取消选中状态

4避免产生大量的viewstate

方案:使用repeater+input(checkbox)+input(hidden)

html代码
复制代码 代码如下:

<asp:repeater runat="server" id="rpt_reporttype">
<itemtemplate>
<input type="checkbox" value='<%#eval("id") %>' onclick="{var next = $(this).next();if($(this).attr('checked')){next.val($(this).val())}else{next.val('')}}" runat="server"/><%#eval("typename")%>
<input type="hidden" name="reporttype"/>
</itemtemplate>
<alternatingitemtemplate>
<input type="checkbox" value='<%#eval("id") %>' onclick="{var next = $(this).next();if($(this).attr('checked')){next.val($(this).val())}else{next.val('')}}" runat="server"/><%#eval("typename")%>
<input type="hidden" name="reporttype"/>
</alternatingitemtemplate>
</asp:repeater>

注:尽量把里面的onclick中的匿名函数代码写在页头.

js代码
复制代码 代码如下:

$(":hidden[name='reporttype']").each(function () {
var obj = $(this).prev();
if (obj.attr('checked')){ $(this).val(obj.val()); }
});

当post提交时后台获取
复制代码 代码如下:

string[] _str = request["reporttype"].split(',');

字符串数据不可避免的会有空字符串,注意删选,否则在拆箱时会出现类型转换异常

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网