在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
之前在网上看了很多,其实有一些也是大同小异,本人在此小编一下大致解决方案摒弃微软提供的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(','); 字符串数据不可避免的会有空字符串,注意删选,否则在拆箱时会出现类型转换异常 |
请发表评论