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

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

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

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

您可能感兴趣的文章:

  • 一篇文章教你如何排查.NET内存泄漏
  • 分析Netty直接内存原理及应用
  • .Net程序内存异常的原因及解决
  • .Net Core内存回收模式及性能测试对比分析
  • asp.net中C#实现手动回收内存的方法
  • 基于.NET BitmapImage 内存释放问题的解决方法详解
  • asp.net 获取机器硬件信息(cpu频率、磁盘可用空间、内存容量等)
  • Net内存管理五大基础

本文由 华域联盟 原创撰写:华域联盟 » asp.net动态产生checkbox(数据源为DB或内存集合)

转载请保留出处和原文链接:https://www.cnhackhy.com/52017.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部