Multiple choices in ASP.NET and pages

xiaoxiao2021-03-06  60

This article describes how to implement multi-page selection in ASP.NET. Its specific ideas are simple: remember each selected item with hidden INPUT, check the saved value when the data binding is performed, and then displayed in the DataGrid. The complete code and examples of time:

View example

Selectmultipages.aspx

<% @ Page EnableViewState = "true" CodeBehind = "SelectMultiPages.aspx.cs" Language = "c #" AutoEventWireup = "false" Inherits = "eMeng.Exam.SelectMultiPages"%> Cross page implementation multi-selection </ title> <meta http-equiv =" content-type "content =" text / html; charSet = GB2312 " > <style> * {font-size: 12px} #status {text-align: left} </ style> <script language = "javascript"> Function addRemoveValues ​​(Ochk) {// Need to pay attention to this place: The value you saved should be unique, so that the error will be replaced.</p> <p>if (oChk.checked) SelectMultiPage.HdnSelectedValues.value = "," oChk.value; elseSelectMultiPage.HdnSelectedValues.value = SelectMultiPage.HdnSelectedValues.value.replace ( "," oChk.value, "");} </ script> </ HEAD> <BODY> <form id = "SelectMultiPage" runat = "server"> <asp: datagrid id = "DataGrid1" HorizontalAlign = "Center" AutoGenerateColumns = "False" Width = "600px" AllowPaging = "True "runat =" server "> <AlternatingItemStyle BackColor =" # EEEEEE "> </ AlternatingItemStyle> <HeaderStyle BackColor =" # AAAADD "Font-Bold =" True "HorizontalAlign =" Center "> </ HeaderStyle> <PagerStyle HorizontalAlign =" Right "Mode =" NumericPages "Visible =" True "> </ PagerStyle> <Columns> <asp: TemplateColumn HeaderText =" select "> <ItemTemplate> <input type =" checkbox "runat =" server "id =" chkSelect " οnclick = "addremovevalues ​​(this)" value = '<% # databinder.eval (container.dataitem, "title")%>' /> </ itemtemplate> <asp: templateColumn> <ask: templatecolumn headertext = article title "> <Itemtemplate> <asp: literal text = '<% # databinder.eval (container.dat) AITEM, "TITLE"%> 'Runat = "Server" id = "titleshow" /> </ itemtemplate> </ ask: templateColumn> <ask: templateColumn headertext = "Published"> <itemtemplate> <ask: Literal Text = '<<</p> <p>% # DataBinder.eval (Container.DataItem, "Createdate"). Tostring ()%> 'Runat = "Server" /> </ itemtemplate> </ asp: templateColumn> </ columns> </ ask: DataGrid> <DIV Align = center> <ask = "Button1" runat = "server" text = "get selected value> </ asp: button> <div id =" status "> <ask: label id =" label1 "Runat =" server "> </ asp: label> </ div> <input id =" hdnselectedvalues ​​"type =" hidden "name =" hdnselectedVALUES "runat =" server "> </ div> </ form> </ Body> </ html> selectmultipages.aspx.cs</p> <p>using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Data.OleDb; using System.Drawing; using System.Web; using System.Web.SessionState; using System.Web.UI; using System.Web.ui.WebControls; use system.web.ui.htmlcontrols;</p> <p>Summary description of Namespace Emeng.exam {/// <summary> /// selectmultipages. /// </ summary> public class SelectMultiPages: System.Web.UI.Page {protected System.Web.UI.WebControls.Button Button1; protected System.Web.UI.WebControls.Label Label1; protected System.Web.UI. HtmlControls.htmlinputhidden hdnselectedvalues; protected system.web.ui.webcontrols.dataGrid DataGrid1;</p> <p>private void Page_Load (object sender, System.EventArgs e) {// Put user code to initialize the page here if BindData () (Page.IsPostBack!);} private void DataGrid1_PageIndexChanged (object source, DataGridPageChangedEventArgs e) {DataGrid1.CurrentPageIndex = E.NewpageIndex; binddata ();</p> <p>void BindData () {OleDbConnection cn = new OleDbConnection ( "Provider = Microsoft.Jet.OLEDB.4.0; Data Source =" HttpContext.Current.Server.MapPath ( "aspx.mdb")); OleDbDataAdapter da = new OleDbDataAdapter ( " Select Title, CreateDate from Document ", cn); DataSet ds = new DataSet (); da.Fill (ds); DataGrid1.DataSource = ds; DataGrid1.DataBind ();} private void DataGrid1_ItemDataBound (object sender, System.Web. UI.WebControls.DataGriditeMeventargs e) {// Re-displays the selected item IF (E.Item.ItemType == ListItemType.Item || E.Item.itemType == ListItemType.AlternatingItem) {if (hdnselectedvalues.Value.indexof (LITERAL) E.Item.cells [1] .FindControl ("titleshow"))))))))))))))))))))))))))))))))))))))))))))))))))))). ); Chkselected.checked = true;}}} private void button1_click (object sender, system.eventargs e) {// for easy replacement of Label1.Text = hdnselexValues.Value.Replace (",", "<li > ");</p> <p>#Region Web Form Designer Generated Code Override Protected Void OnNit (Eventargs E) {// // Codegen: This call is required for the ASP.NET Web Form Designer. // InitializeComponent (); base.oninit (e);</p> <p>/// <summary> /// Designer supports the required method - do not use the code editor to modify the // / this method. /// </ summary> private void InitializeComponent () {this.DataGrid1.ItemDataBound = new System.Web.UI.WebControls.DataGridItemEventHandler (this.DataGrid1_ItemDataBound); this.DataGrid1.PageIndexChanged = new System.Web.UI. WebControls.DataGridPageChangedEventHandler (this.DataGrid1_PageIndexChanged); this.Button1.Click = new System.EventHandler (this.Button1_Click); this.Load = new System.EventHandler (this.Page_Load);</p> <p>} #endregion</p> <p>}</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-109686.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="109686" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.034</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = '_2Bl0IGY5ep31Uije7QJzplUfxm61SCYSrfMmBDzSICujzUdu_2BvpDj8fYDGTefTefkzUAM2V5UIt_2BhGHHymhq2OA_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>