Question

J'ai demandé cela, mais malheureusement, je suis encore avoir des problèmes et la question n'a pas été résolue. Fondamentalement, je crée dynamiquement un LinkButton pour chaque rangée d'une table je générer, et en ce que le bouton a pour tâche de supprimer la rangée correspondant à l'ID de la base de données. Pour ce faire, je dois apparemment assigner le LinkButton une commande il va dans l'événement quand il est cliqué. Le problème est, lorsque le bouton de cliqués le programme jamais va dans la commande - j'ai mis des points d'arrêt là-dedans et il ne va jamais en eux. Voici mon code:

protected void Page_Init(object sender, EventArgs e)
        {
            if (Request.QueryString["id"] != null)
            {

                ColorConverter conv = new ColorConverter();
                string connection = ConfigurationManager.ConnectionStrings["TPRTestConnectionString"].ConnectionString;
                TPRDBDataContext dc = new TPRDBDataContext();
                DataContext db = new DataContext(connection);
                Table<SageAccount> SageAccount = db.GetTable<SageAccount>();
                Table<InvoiceItem> InvoiceItem = db.GetTable<InvoiceItem>();
                Table<Invoice> Invoice = db.GetTable<Invoice>();
                Boolean alloweditting = (from s in dc.Invoices where s.id.ToString() == Request.QueryString["id"] select s.alloweditting).Single();
                if (alloweditting == false)
                {
                    dtlsInsert.Visible = false;
                    modalPanel.Visible = false;
                }
                int sagepk = (from s in dc.Invoices where s.id.ToString() == Request.QueryString["id"] select s.sageaccount).Single();
                lblSageID.Text = (from s in dc.SageAccounts where s.ID == sagepk select s.SageID).Single();
                lblDate.Text = DateTime.Now.ToShortDateString();


                Table table = new Table();
                table.Width = Unit.Percentage(100);
                table.GridLines = (GridLines)3;

                TableHeaderRow header = new TableHeaderRow();
                header.BackColor = (System.Drawing.Color)conv.ConvertFromString("#EDEDED");
                foreach (string header2 in new string[] { "", "Quantity", "Rate", "Description", "Nominal Code", "Subtotal" })
                {
                    TableCell cell = new TableCell();
                    cell.Text = header2;
                    header.Cells.Add(cell);
                }

                table.Rows.Add(header);

                var data = (from s in dc.InvoiceItems where s.invoiceid.ToString() == Request.QueryString["id"].ToString() select s);
                foreach (var x in data)
                {

                    TableRow row = new TableRow();
                    if (x.invoicetext == null)
                    {
                        decimal total;
                        try
                        {
                            total = (decimal)x.rate * (decimal)x.quantity;
                        }
                        catch
                        {
                            total = 0;
                        }
                        int i = 0;
                        foreach (string columnData in new string[] { x.id.ToString(), x.quantity.ToString(), x.rate.ToString(), x.description, x.nominalcode, total.ToString("N2") })
                        {
                            TableCell cell = new TableCell();
                            {
                                if (i == 0)
                                {
                                    LinkButton lnkdel = new LinkButton();
                                    lnkdel.Text = "Delete";
                                    lnkdel.ID = "lnkDel" + Guid.NewGuid();

                                    if (alloweditting == false)
                                    {
                                        lnkdel.Enabled = false;
                                    }
                                    lnkdel.Font.Bold = false;
                                    lnkdel.CommandArgument = x.id.ToString();
                                    //lnkdel.Command += lnkdel_Command;
                                    //lnkdel.Command += new CommandEventHandler(this.lnkdel);
                                    cell.Controls.Add(lnkdel);
                                    i++;
                                }
                                else
                                {
                                    cell.Text = columnData;
                                }


                            }

                            row.Cells.Add(cell);
                        }



                        runningtotal = runningtotal + total;

                    }
                    else
                    {
                        int i = 0;

                        foreach (string columnData in new string[] { x.id.ToString(), x.invoicetext })
                        {
                            TableCell cell = new TableCell();

                            if (i == 0)
                            {
                                LinkButton lnkdel = new LinkButton();
                                lnkdel.Text = "Delete";
                                lnkdel.ID = "lnkDel" + Guid.NewGuid();

                                if (alloweditting == false)
                                {
                                    lnkdel.Enabled = false;
                                }
                                lnkdel.Font.Bold = false;
                                          //lnkdel.Command += lnkdel_Command;
                                    //lnkdel.Command += new CommandEventHandler(this.lnkdel);
                                lnkdel.CommandArgument = x.id.ToString();



                                cell.Controls.Add(lnkdel);
                                i++;
                            }
                            else
                            {
                                cell.Text = columnData;
                                cell.ColumnSpan = 5;
                            }
                            row.Cells.Add(cell);

                        }

                    }

                    switch (x.formatoptions)
                    {
                        case 1:
                            row.ForeColor = (System.Drawing.Color)conv.ConvertFromString("black");
                            row.Font.Bold = false;
                            break;
                        case 2:
                            row.ForeColor = (System.Drawing.Color)conv.ConvertFromString("black");
                            row.Font.Bold = true;
                            break;
                        case 3:
                            row.ForeColor = (System.Drawing.Color)conv.ConvertFromString("red");
                            row.Font.Bold = false;
                            break;
                        case 4:
                            row.ForeColor = (System.Drawing.Color)conv.ConvertFromString("red");
                            row.Font.Bold = true;
                            break;
                    }
                    table.Rows.Add(row);
                }

                TableFooterRow row2 = new TableFooterRow();
                TableCell cell2 = new TableCell();
                cell2.Text = "<span style\"text-align: right; width: 100%;\">Total = <b>" + runningtotal.ToString("N2") + "</b></span>";
                cell2.ColumnSpan = 6;
                row2.Cells.Add(cell2);
                table.Rows.Add(row2);

                var update = (from s in dc.Invoices where s.id.ToString() == Request.QueryString["id"] select s).Single();
                update.total = runningtotal;

                dc.SubmitChanges();
                datatable.Controls.Clear();
                datatable.Controls.Add(table);
            }
            else
            {
                Response.Redirect("Invoices.aspx");
            }
        }

        protected void Page_Load(object sender, EventArgs e)
        {



        }


        protected void lnkdel_Command(object sender, CommandEventArgs e)
        {
            string connection = ConfigurationManager.ConnectionStrings["TPRTestConnectionString"].ConnectionString;


            using (SqlConnection conn = new SqlConnection(connection))
            {
                SqlCommand comm = new SqlCommand("DELETE FROM InvoiceItem WHERE id = @id", conn);
                comm.Parameters.AddWithValue("@id", e.CommandArgument.ToString());
                conn.Open();
                try
                {
                    comm.ExecuteNonQuery();
                }
                catch (Exception ex)
                {
                    Response.Write(ex);
                }
            }
    }

Notez que je l'ai commenté sur 2 des lignes cruciales pour l'affichage ici, juste pour dire que je l'ai essayé les deux lignes qui est commenté et ni le travail: (

Était-ce utile?

La solution

Vous devez ajouter les commandes tous postback. Vous semblez ne les créer sur le get initial (que la vérification de la chaîne de requête). Sur le dos après, ces contrôles ne sont recréés donc pas événement se déclenche.

Il est notoirement contre-intuitif, mais alors que ASP.NET se penche en arrière pour vous faire croire que l'instance de votre classe de page est le même entre deux requêtes HTTP, la réalité est qu'ils ne sont pas les mêmes. Une nouvelle instance est créée chaque fois. On dirait que vous essayez d'éviter d'ajouter les contrôles générés dynamiquement plusieurs fois - vous ne voulez pas que la pensée des doublons. La réalité est que vous jamais obtenir des doublons lors de l'ajout de contrôles générés dynamiquement dans une méthode de cycle de vie tels que OnInit() puisqu'il est toujours une nouvelle instance de la classe de page, et donc les commandes générées dynamiquement sont partis.

La raison pour cela est généralement transparent pour les développeurs est que tous les contrôles dans le code avant sont à nouveau générés automatiquement pour vous à la fois sur la demande initiale et chaque post-retour. Pour vos commandes créées dynamiquement, il vous arrive d'avoir cette ligne:

if (Request.QueryString["id"] != null) { ... }

À moins que vous faites quelque chose de spécial, cet attribut « id » ne sera pas dans la chaîne de requête sur le postback. Cela signifie que le code intégré dans le bloc if sera exécuté sur le dos de poste (quand votre événement se déclenche en fait.) Cela signifie que votre if vérification en haut doit être retiré complètement. Tous ce code devrait fonctionner pour chaque demande (GET et POST).

Autres conseils

Il suffit de dire que j'ai créé une solution de contournement - créant simplement un lien simple à la page, ainsi que d'une chaîne de requête contenant l'identifiant de la ligne à supprimer

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top