asp.net 动态产生checkbox

来源:互联网 发布:无损音乐分割软件 编辑:程序博客网 时间:2024/05/21 19:21

之前在网上看了很多,其实有一些也是大同小异,本人在此小编一下大致解决方案


摒弃微软提供的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(',');
字符串数据不可避免的会有空字符串,注意删选,否则在拆箱时会出现类型转换异常


原创粉丝点击