asp.net动态产生checkbox(数据源为DB或内存集合)
网络编程 2021-07-04 22:40www.168986.cn编程入门
动态产生一组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(',');
字符串数据不可避免的会有空字符串,注意删选,否则在拆箱时会出现类型转换异常
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程