asp.net动态产生checkbox(数据源为DB或内存集合)
更新时间:2013年10月10日 16:18:56 作者:
动态产生一组checkbox(数据源为DB或内存集合)且post提交时后台能及时获取等等,打算使用repeater+input(checkbox)+input(hidden)来实现
之前在网上看了很多,其实有一些也是大同小异,本人在此小编一下大致解决方案摒弃微软提供的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(',');
字符串数据不可避免的会有空字符串,注意删选,否则在拆箱时会出现类型转换异常
需求:
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中的弱引用字典WeakDictionary和ConditionalWeakTable介绍
这篇文章介绍了.Net中的弱引用字典WeakDictionary和ConditionalWeakTable,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-06-06asp.net中DBNull.Value,null,String.Empty区别浅析
这篇文章来给大家介绍asp.net中DBNull.Value,null,String.Empty区别浅析,有需要的同学可以参考一下2013-08-08.NET Core中的HttpClientFactory类用法详解
本文详细讲解了.NET Core中的HttpClientFactory类的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-03-03使用 Visual Studio 的“代码度量值”来改进代码质量
代码度量是一组软件度量值,使开发人员可以更好地了解他们正在开发的代码.这篇文章主要介绍了通过 Visual Studio 的“代码度量值”来改进代码质量,需要的朋友可以参考下2017-11-11
最新评论