之前在網上看了很多,其實有一些也是大同小異,本人在此小編一下大致解決方案摒棄微軟提供的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(',');
字串資料不可避免的會有Null 字元串,注意刪選,否則在拆箱時會出現類型轉換異常