繁体   English   中英

如何在 asp:dropdownlist after.Page?IsPostBack 中保留我的项目?

[英]How do I keep my items in asp:dropdownlist after !Page.IsPostBack?

我通过调用存储过程将值/文本列表加载到 asp:dropdownlist 中。 我在 a.Page:IsPostBack 块内的 PageLoad 方法上填充下拉列表,如下所示:

if (!Page.IsPostBack)
{
     GetDropDownLists();
     DataBind();
}

这是我的后端代码实现:

protected void GetDropDownLists()
{
     DataTable dt = new DataTable();

     SqlConnection conn = new SqlConnection(connString);
     SqlCommand cmd = new SqlCommand("get_articletype", conn);
     cmd.CommandType = CommandType.StoredProcedure;
     SqlDataAdapter adapter = new SqlDataAdapter(cmd);
               
     adapter.Fill(dt);
     xArticleTypeList.Items.Clear();
     xArticleTypeList.Items.Insert(0, new ListItem("- Select.. -", "0"));
     xArticleTypeList.SelectedIndex = 0;
     xArticleTypeList.DataSource = dt;
     xArticleTypeList.DataValueField = "TypeValue";
     xArticleTypeList.DataTextField = "TypeName";
     xArticleTypeList.DataBind();
}

如果我的代码不在 a.Page,IsPostBack 块内。 单击保存按钮后,默认值将始终是下拉列表的第一项。 但是,一旦我将代码放入 .Page:IsPostBack 块中,我的下拉列表就是空的。 这里的参考是我的 asp:dropdownlist 的前端实现。

<asp:DropDownList ID="xArticleTypeList" EnableViewState="true" AutoPostBack="true" CssClass="form-control" runat="server" />

我知道还有其他主题涵盖了这个问题,但没有一个建议的解决方案对我有用。 提前感谢您的投入。

您的问题是您在绑定之前插入空白请 select 行。 结果,当您绑定时,您正在吹掉下拉列表。

试试这种方式:

   protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
            LoadData();
    }


    void LoadData()
    {
        using (SqlConnection conn = new SqlConnection(Properties.Settings.Default.TEST4))
        {
            using (SqlCommand cmd = new SqlCommand("get_articletype", conn))
            {
                DataTable dt = new DataTable();
                cmd.CommandType = CommandType.StoredProcedure;
                conn.Open();
                dt.Load(cmd.ExecuteReader());

                xArticleTypeList.DataSource = dt;
                xArticleTypeList.DataValueField = "TypeValue";
                xArticleTypeList.DataTextField = "TypeName";
                xArticleTypeList.DataBind();

                xArticleTypeList.Items.Insert(0, new ListItem("- Select.. -", "0"));
            }
        }
    }

并 GET RID of your extra call re-bind 你有这个:

 GetDropDownLists();
 DataBind();   <--- remove unless you need, or execute BEFORE the GetDropDownList()

因此,将您的添加/插入空白行移动到下拉数据绑定之后。

并删除你的 DataBind() - 你不需要它,如果由于某种原因你需要它,然后将 DataBind() 移动到加载 GetDropDownLists() 之前 - 但我的猜测是你只是希望扔掉它做这项工作,它会导致组合框重新选择 - 所以删除,除非你给出一个非常好的高质量大纲和叙述你为什么在那里有 DataBin() 命令 - (但如前所述,如果您确实,但确实确实需要执行该 DataBind() 命令-将其移至组合加载之前)。

所以,在后面添加空白行

暂无
暂无

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

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