服务器之家

服务器之家 > 正文

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

时间:2019-11-19 13:27     来源/作者:asp.net教程网

之前在网上看了很多,其实有一些也是大同小异,本人在此小编一下大致解决方案摒弃微软提供的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(','); 


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

标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
运维必须知道的关于云服务器的十个问题
运维必须知道的关于云服务器的十个问题 2019-05-24
返回顶部