(Original) An example of a dynamic template column update data paging

xiaoxiao2021-03-06  17

Http://blog.9cbs.net/lovecherry/archive/2005/03/25/329977.Aaspx The last example of the dynamic template column, netizen asked me how to update the operation and page, give the code below . Front desk: <% @ page language = "c #" codebehind = "Webform30.aspx.cs" autoeventwireup = "false" inherits = "9cbs.webform30"%> Webform30 </ title> <meta name =" generator "content =" Microsoft Visual Studio .NET 7.1> <meta name = "code_language" content = "c #"> <meta name = "vs_defaultclientscript" content = "javascript"> <link href = "css.css" rel = "stylesheet" type = "text / css"> <meta name = "vs_targetschema" content = "http: // Schemas .microsoft.com / IntelliSense / IE5 "> </ head> <body ms_positioning =" gridLayout "> <form id =" form1 "method =" post "runat =" server "> <ask: DataGrid ID =" DataGrid1 "Runat = "Server"> </ ask: DataGrid> </ form> </ body> </ html> background: use system; using system.collections; using system.componentmodel; using system.data; using system.data.sqlclient; Using system.drawing; using system.web; using system.Web.SessionState; using system.web.ui; using system.web.ui.webcontrols; using system.web.ui.htmlcontrols;</p> <p>Namespace 9CBS {/// <summary> /// WebForm 30 summary description. /// </ summary> public class WebForm30: System.Web.UI.Page {protected System.Web.UI.WebControls.DataGrid DataGrid1; private void Page_Load (object sender, System.EventArgs e) {// Here placed user code to initialize the page if (! IsPostBack) {BindGrid ();} CreateDataGrid (); // some settings DataGrid} protected void CreateDataGrid () {DataGrid1.AutoGenerateColumns = false; // do not auto-generated columns DataGrid1.CssClass = "border"; // border style DataGrid1.BorderWidth = 0; DataGrid1.CellSpacing = 1; DataGrid1.CellPadding = 5; DataGrid1.ItemStyle.CssClass = "item"; // common column style DataGrid1.HeaderStyle.CssClass = "header "; // head style DataGrid1.pagerstyle.cssclass =" header "; // footer style DataGrid1.DataKeyfield =" stuid "; // Primary key field DataGrid1.allowpaging = true; // Allow paging DataGrid1.pageSize = 5; / / page size DataGrid1.PagerStyle.Mode = PagerMode.NumericPages; // digital form tab EditCommandColumn ecc = new EditCommandColumn (); // update button column ecc.ButtonType = ButtonColumnType.PushButton; // push button ecc.EditText = "edit "; Ecc.canceltExt =" Cancel "; ECC.UpdateText =" Update "; // Button text DataGrid1.columns. Add (ecc); // Add button column DataGrid1.EditCommand = new DataGridCommandEventHandler (DataGrid1_EditCommand); DataGrid1.UpdateCommand = new DataGridCommandEventHandler (DataGrid1_UpdateCommand); DataGrid1.CancelCommand = new DataGridCommandEventHandler (DataGrid1_CancelCommand); // update, cancel, edit event registration DataGrid1 .PageIndexChanged = new System.Web.UI.WebControls.DataGridPageChangedEventHandler (DataGrid1_PageIndexChanged); // paging event registration, event noted here that the location registration code, can not be put BindGrid () in SetBind (); //} binding data</p> <p>protected void BindGrid () {TemplateColumn tm = new TemplateColumn (); tm.ItemTemplate = new ColumnTemplate1 (); // common column tm.EditItemTemplate = new ColumnTemplate2 (); // edit column tm.HeaderText = "name"; DataGrid1. Columns.AddAt (0, tm); // first template increase TemplateColumn tm2 = new TemplateColumn column in the first row (); tm2.ItemTemplate = new ColumnTemplate3 (); tm2.EditItemTemplate = new ColumnTemplate4 (); tm2.HeaderText = "Academy"; DataGrid1.columns.addat (1, TM2); // Increase the first template column of the first template column in the second column DataGrid1.ItemDatabaseTABOUNDLERS.DATAGRIDITEMEVENTHANDLER (DataGrid1_itemdatabase); // Data binding event registration, event noted here that the location registration code SetBind ();} protected void SetBind () {SqlConnection conn = new SqlConnection (System.Configuration.ConfigurationSettings.AppSettings [ "conn"]); SqlDataAdapter da = new SqlDataAdapter ( "Select * from stu, depist = dep.depid", conn; dataset ds = new dataset (); da.fill (DS, "Table1"); this.DataGrid1.datasource = ds.tables [" Table1 "]; this.DataGrid1.databind ();</p> <p>private void DataGrid1_ItemDataBound (object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) {SqlConnection conn = new SqlConnection (System.Configuration.ConfigurationSettings.AppSettings [ "conn"]); SqlDataAdapter da = new SqlDataAdapter ( "select * from dep ", conn); DataSet DS = New Dataset (); DA.FILL (DS," Table1 "); if (E.Item.itemType == ListItemType.editItem) {DropDownList DDL = (DropDownList) E.Item.FindControl "dep"); ddl.datasource = ds.tables ["Table1"]; ddl.datatextfield = "depname"; DDL.DataValuefield = "depid"; ddl.database (); ddl.items.FindByValue (Convert.Tostring . DataBinder.Eval (e.Item.DataItem, "depid"))) Selected = true;}} private void DataGrid1_EditCommand (object source, System.Web.UI.WebControls.DataGridCommandEventArgs e) {this.DataGrid1.EditItemIndex = e. Item.itemindex; bindgrid ();</p> <p>Private void DataGrid1_cancelcommand (Object Source, System.Web.ui.WebControls.DataGridCommandeventArgs E) {this.DataGrid1.editItemIndex = -1; bindgrid ();</p> <p>private void DataGrid1_UpdateCommand (object source, System.Web.UI.WebControls.DataGridCommandEventArgs e) {string uid = e.Item.UniqueID ":"; // careful not to miss the colon SqlConnection conn = new SqlConnection (System.Configuration.ConfigurationSettings.AppSettings [ "conn"]); SqlCommand comm = new SqlCommand ( "update stu set stuname = @ name, studepid = @ depid where stuid = @ id", conn); SqlParameter parm1 = new SqlParameter ( "@ name", SqlDbType.NVarChar , 50); PARM1.VALUE = Request.form [UID "Name"]. TOSTRING (); SQLParameter PARM2 = New SQLParameter ("@ depid", sqldbtype.int); parm2.value = request.form [UID "DEP" ] .Tostring () ;; sqlparameter parm3 = new sqlparameter ("@ id", sqldbtype.int); parm3.value = this.dataGrid1.DataKeys [E.Item.itemindex]; Comm.Parameters.Add (PARM1); Comm. .Parameters.Add (PARM2); Comm.Parameters.Add (PARM3); conn.open (); Comm.ExecutenonQuery (); conn.close (); this.dataGrid1.edititeMindex = -1; bindgrid (); // The reason why the previous (TextBox) E.Item.FindControl ("Name")). When you get the data, the DataGrid column is dynamically added, it is not available. ate void DataGrid1_PageIndexChanged (object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e) {this.DataGrid1.CurrentPageIndex = e.NewPageIndex; BindGrid ();}</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.onit (e);} /// <summary> /// Designer Supports the required method - Do not use the code editor to modify the // / this method. /// </ summary> private () {this.load = new system.eventhandler (this.page_load);</p> <p>} #Endregion}</p> <p>public class ColumnTemplate1: ITemplate {public void InstantiateIn (Control container) {LiteralControl l = new LiteralControl (); l.DataBinding = new EventHandler (this.OnDataBinding); container.Controls.Add (l);} public void OnDataBinding (object Sender, Eventargs E) {LiteralControl L = (Literal Control) Sender; DataGridItem Container = (DataGridItem) L.NamingContainer; L.Text = ((DATAROWVIEW) Container.DataItem) ["stuname"]. Tostring ();}}</p> <p>Public class columnTemplate2: itemplate {public void instantiatein (control container) {textbox t = new textbox (); t.width = 88; t.id = "name"; // Need to give an ID, in Request.form Take T.DATABINDING = New EventHandler (this.ondatabase); Container.Controls.Add (T);}</p> <p>public void OnDataBinding (object sender, EventArgs e) {TextBox t = (TextBox) sender; DataGridItem container = (DataGridItem) t.NamingContainer; t.Text = ((DataRowView) container.DataItem) [ "stuname"] ToString (). ; // Bind the stuname field}}}</p> <p>public class ColumnTemplate3: ITemplate {public void InstantiateIn (Control container) {LiteralControl l = new LiteralControl (); l.DataBinding = new EventHandler (this.OnDataBinding); container.Controls.Add (l);}</p> <p>public void OnDataBinding (object sender, EventArgs e) {LiteralControl l = (LiteralControl) sender; DataGridItem container = (DataGridItem) l.NamingContainer; l.Text = ((DataRowView) container.DataItem) [ "depname"] ToString (). }}</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-42253.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="42253" 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.046</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 = '0uFW0eMWiLFpjnsSPHEva9MHrQ_2FUdmV08QqaljJGfB5WyaksVU7RJxGvaXewWmjoiF3aw2DqPaVhpvgJovPAdA_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>