C# Hashtable 不保留值

标签 c# asp.net hashtable

我正在使用哈希表来存储键值对,并在方法 CreateDropDownLists() 中初始化此哈希表 (ddl_ht)。但是,当我在 SelectedIndexChanged 方法中检查“currentItem”的值时,该值为空。即使我检查了

的值

(string)ddl_ht[key[1]]

在我的监 window 口中,它显示了一个值(非空)。你明白为什么这个 currentItem 是 null 吗?

using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using ADONET_namespace;

namespace AddFileToSQL
{
    public partial class DataMatch : _Default
    {
        protected System.Web.UI.WebControls.PlaceHolder phTextBoxes;
        protected System.Web.UI.WebControls.PlaceHolder phDropDownLists;
        protected System.Web.UI.WebControls.Button btnAnotherRequest;
        protected System.Web.UI.WebControls.Panel pnlCreateData;
        protected System.Web.UI.WebControls.Literal lTextData;
        protected System.Web.UI.WebControls.Panel pnlDisplayData;

        protected static string inputfile2;
        static string[] headers = null;
        static string[] data = null;
        static string[] data2 = null;
        static DataTable myInputFile = new DataTable("MyInputFile");
        static string[] myUserSelections;
        static Hashtable ddl_ht = new Hashtable();

        // Page Load 
        private void Page_Load(object sender, System.EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                this.NumberOfControls = 0;
            }
        }

        // Add DropDownList Control to Placeholder
        private void CreateDropDownLists()
        {
            for (int counter = 0; counter < NumberOfControls; counter++)
            {
                DropDownList ddl = new DropDownList();
                SqlDataReader dr = ADONET_methods.DisplayTableColumns(targettable);
                ddl.ID = "DropDownListID " + (counter + 1).ToString();
                ddl.DataTextField = "COLUMN_NAME";
                ddl.DataValueField = "COLUMN_NAME";
                ddl.DataSource = dr;
                ddl.DataBind();

                //myUserSelections[counter] = "";

                ddl.AutoPostBack = true;
                ddl.EnableViewState = true; //Preserves View State info on Postbacks
                ddl.Style["position"] = "absolute";
                ddl.Style["top"] = 100 * counter + 80 + "px";
                ddl.Style["left"] = 250 + "px";
                ddl.SelectedIndexChanged += new EventHandler(SelectedIndexChanged);
                ddl_ht.Add(counter, ddl.SelectedValue);

                pnlDisplayData.Controls.Add(ddl);
                pnlDisplayData.Controls.Add(new LiteralControl("<br><br><br>"));
                pnlDisplayData.Visible = true;
                pnlDisplayData.FindControl(ddl.ID);
               // pnlDropDownList.FindControl(ddl.ID);
                dr.Close();
            }
        }

        protected void SelectedIndexChanged(object sender, EventArgs e)
        {
            DropDownList ddl = (DropDownList)sender; 
            string[] value=(ddl.SelectedValue).Split(' ');
            string[] key = ddl.ID.Split(' ');
            string currentItem=(string)ddl_ht[key[1]];
            //if (String.IsNullOrEmpty(currentItem))
            //{
            //    ddl_ht.Add(key[1], value[0]);
            //}
            if (currentItem != ddl.SelectedValue)
            {
                ddl_ht.Remove(key[1]);
                ddl_ht.Add(key[1], ddl.SelectedValue);
            }
        }

        // Add TextBoxes Control to Placeholder
        private void RecreateDropDownLists()
        {
            for (int counter = 0; counter < NumberOfControls; counter++)
            {
                DropDownList ddl = new DropDownList();
                SqlDataReader dr = ADONET_methods.DisplayTableColumns(targettable);

                ddl.ID = "DropDownListID " + (counter + 1).ToString();
                ddl.DataTextField = "COLUMN_NAME";
                ddl.DataValueField = "COLUMN_NAME";
                ddl.DataSource = dr;
                ddl.DataBind();
                myUserSelections[counter] = "";
                dr.Close();

                ddl.AutoPostBack = true;
                ddl.EnableViewState = true; //Preserves View State info on Postbacks
                ddl.Style["position"] = "absolute";
                ddl.Style["top"] = 100 * counter + 80 + "px";
                ddl.Style["left"] = 250 + "px";
                ddl.SelectedIndexChanged += new EventHandler(SelectedIndexChanged);
                pnlDisplayData.Controls.Add(ddl);
                pnlDisplayData.Controls.Add(new LiteralControl("<br><br><br>"));
            }
        }

        // Create TextBoxes and DropDownList data here on postback.
        protected override void CreateChildControls()
        {
            // create the child controls if the server control does not contains child controls
            this.EnsureChildControls();

            // Creates a new ControlCollection. 
            this.CreateControlCollection();

            // Here we are recreating controls to persist the ViewState on every post back
            if (Page.IsPostBack)
            {
                RecreateDropDownLists();
                RecreateLabels();
            }
            // Create these conrols when asp.net page is created
            else
            {
                PopulateFileInputTable();
                CreateDropDownLists();
                CreateLabels();
            }

            // Prevent child controls from being created again.
            this.ChildControlsCreated = true;
        }

    }
}

最佳答案

您将遇到此设置的各种线程问题。您的哈希表是静态的,您网站上的每次点击都将在一个新线程上创建您的类的一个新实例,该线程将尝试访问相同的哈希表 - 因为页面的每次新点击最初都会调用 CreateDropDownLists,您的哈希表将为页面的每个新用户重新初始化。

关于C# Hashtable 不保留值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1183776/

相关文章:

java - Hashtable 实现中使用的算法?

c# - 如何提高 FlowDocumentScrollViewer 的性能?

c# - 来自模式的类

c# - 如何从 robots.txt 文件中读取站点地图 url 文本

javascript正则表达式验证函数

c# - 如何在 Blazor 的 onkeypress 方法中读取输入的当前值?

java - 在哈希表中创建字符串的哈希值的时间复杂度

c# - 更新文本框内部文本而不刷新页面

c# - Blazor jquery select2 双向绑定(bind)

php - 如何从嵌套数组创建哈希表 (php)