繁体   English   中英

删除动态创建的 HTML 表格行 - 生命周期/视图状态问题

[英]Removing dynamically created HTML table rows - Life Cycle / Viewstate problem

所以我有一个 HTML 表,其中包含动态添加的行和 ASP.NET 文本框。 如果 viewstate[dataonpage] = true,我会在 page_load 上重新实例化行和控件,并且我在添加行和控件的方法中将其声明为 true。 (我需要他们坚持其他回发)

问题是我现在添加了一个CLEAR 按钮,该按钮在单击时删除所有 html 行(不包括标题),并且由于某种原因单击按钮时会出现索引错误,或者如果使用 Try/Catch它只删除一半的行(每隔一行)。 我认为问题与 viewstate[dataonpage] 仍然是“true”有关,并且在页面加载时重新添加数据。 如果我将 viewstate["dataonpage"] = "false" 添加到清除按钮方法中,也会发生同样的情况,但至少在第二次单击时会以这种方式删除行的后半部分。

我知道发生这种情况是因为按钮事件处理程序直到 page_load 之后才会触发,这就是它在第一次点击时不起作用的原因。 但我不完全理解的是,为什么即使没有这个,我的清除按钮代码也不会首先清除所有行。

任何有助于理解为什么它不起作用的帮助,以及解决方法将不胜感激!

protected void Page_Load(object sender, EventArgs e)
        {
            if (Convert.ToString(ViewState["DataOnPage"]) == "true")
                {
                    Getmarketdata();
                }
        }
protected void Getdatabtn_Click(object sender, EventArgs e)
        {
            ViewState["DataOnPage"] = "true";
            Getmarketdata();
        }

下面是创建添加表行和控件的方法:

public void Getmarketdata()
        {
            String url = "https://api.rightmove.co.uk/api/rent/find?index=0&sortType=1&maxDaysSinceAdded=" + Dayssinceuploadtext.Text + "&locationIdentifier=OUTCODE%5e" + Outcodetext.Text + "&apiApplication=IPAD";
            Response.Write(url);

            using (var webclient = new WebClient())
            {
                String Rawjson = webclient.DownloadString(url);
                    ViewState["VSMarketDataJSONString"] = Rawjson;
                dynamic dobj = JsonConvert.DeserializeObject<dynamic>(Rawjson);
                int NoOfHouses = dobj["properties"].Count;
                Response.Write("<br />" + NoOfHouses);
                for (int i = 0; i < NoOfHouses; i++)
                {
                    System.Web.UI.HtmlControls.HtmlTableRow tRow = new System.Web.UI.HtmlControls.HtmlTableRow();
                    GeneratorTable.Rows.Add(tRow);
                    String RMlink = String.Format("https://www.rightmove.co.uk/property-to-rent/property-" + dobj["properties"][i]["identifier"].ToString()) + ".html";
                    HyperLink hypLink = new HyperLink();
                    hypLink.Text = dobj["properties"][i]["identifier"].ToString();
                    hypLink.Target = "_blank";
                    hypLink.NavigateUrl = RMlink;
                    using (System.Web.UI.HtmlControls.HtmlTableCell tb1 = new System.Web.UI.HtmlControls.HtmlTableCell())
                    {
                        tRow.Cells.Add(tb1);
                        tb1.Controls.Add(hypLink);
                    }
                    using (System.Web.UI.HtmlControls.HtmlTableCell tb2 = new System.Web.UI.HtmlControls.HtmlTableCell())
                    {
                        TextBox tbEPCe = new TextBox();
                        tRow.Cells.Add(tb2);
                        tb2.Controls.Add(tbEPCe);
                        String txtboxID = (("EPCETxtBox") + i);
                        tbEPCe.ID = txtboxID;
                        tbEPCe.Style.Add("background", "none"); tbEPCe.Style.Add("border", "1px solid black"); tbEPCe.Style.Add("border-radius", "2px");
                    }
                    using (System.Web.UI.HtmlControls.HtmlTableCell tb3 = new System.Web.UI.HtmlControls.HtmlTableCell())
                    {
                        TextBox tbEPCp = new TextBox();
                        tRow.Cells.Add(tb3);
                        tb3.Controls.Add(tbEPCp);
                        String txtboxID = (("EPCPTxtBox") + i);
                        tbEPCp.ID = txtboxID;
                        tbEPCp.Style.Add("background", "none"); tbEPCp.Style.Add("border", "1px solid black"); tbEPCp.Style.Add("border-radius", "2px");

                    }
                    using (System.Web.UI.HtmlControls.HtmlTableCell tb4 = new System.Web.UI.HtmlControls.HtmlTableCell())
                    {
                        TextBox tbBbl = new TextBox();
                        tRow.Cells.Add(tb4);
                        tb4.Controls.Add(tbBbl);
                        String txtboxID = (("BblTxtBox") + i);
                        tbBbl.ID = txtboxID;
                        tbBbl.Style.Add("background", "none"); tbBbl.Style.Add("border", "1px solid black"); tbBbl.Style.Add("border-radius", "2px");
                    }
                }
            }
        }

下面是清除表格行的方法:(这是一个不起作用的方法)

public void ClearTableRows()
        {
            System.Web.UI.HtmlControls.HtmlTable Htmlgeneratortable = ((System.Web.UI.HtmlControls.HtmlTable)GeneratorTable);
            int NoOfRows = Htmlgeneratortable.Rows.Count;
            for (int j = 1; j < NoOfRows; j++)
            {
                try
                {
                    Htmlgeneratortable.Rows.RemoveAt(j);
                }
                catch
                { }
            }
        }

我将解释发生了什么,因为您现在已经编写了代码; 我不相信我有能力提供答案,包括要进行的确切代码更改,因此您当前的方法有什么问题:

您的表GeneratorTable对所有客户端都存在。 这并不意味着每次有人导航到你的网站产生的表格,就意味着有一个表,每一个客户端登录时获得一个表。

因此,如果您为一个客户端向其中添加行,然后将表发送到另一个客户端,则两个客户端都会看到同一个表(添加了行)。

问题是清空表是与后端服务器无关的逻辑。 没有理由为您的服务器被处理清空一个表,你的服务器应该只处理页面导航和AJAX调用好看多了,它不应该被如何改变网页的外观,因为服务器只能每个客户一次回应。

GeneratorTable响应客户端然后在服务器上更新GeneratorTable有什么意义? 客户端永远不会看到对表所做的更新,除非它们是从服务器重新发送的。

你说你是新手,需要学习 JS 和客户端,这个练习应该作为一个例子,说明为什么你需要在前端放一些代码,在后端放一些代码,因为那里不是真正优雅的方式来做你想要做的只是服务器。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM