簡體   English   中英

在變量中的下拉菜單中分配選定的值

[英]Assign Selected Value in DropDown from Variable

我有一個頁碼下拉列表,可以從數據庫查詢中獲取正確的值。 除了我似乎無法弄清楚如何在下拉列表中保留選定的值之外,此列表一切正常。 頁號通過查詢字符串傳遞,我將其保留為ViewState變量。 我可以通過返回.aspx來確認此變量已正確保留。 我如何將該值設置為選定值,以便在加載新頁面時下拉列表並不總是恢復為“ 1”?

我后面的代碼:

public string proc;

public string page
{
    get { return ViewState["page"] as string; }
    set { ViewState["page"] = value; }
}

protected void Page_Load(object sender, EventArgs e)
{
    page = Request.QueryString["page"];
    Page_Numbers();
}

public void Page_Numbers()
{
    if (proc != null)
    {
        int totalRows;
        int totalPages;

        string sqlConn = ConfigurationManager.ConnectionStrings["DBConnectionString"].ConnectionString;
        SqlConnection sqlConnection1 = new SqlConnection(sqlConn);
        SqlCommand cmd = new SqlCommand();

        cmd.CommandText = (proc);
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Connection = sqlConnection1;

        sqlConnection1.Open();
        totalRows = Convert.ToInt32(cmd.ExecuteScalar());
        totalPages = ((totalRows / 1000) + 1);
        sqlConnection1.Close();

        for (int i = 1; i <= totalPages; i++)
        {
            PageDdl.Items.Add(new ListItem(i.ToString()));

            if (i == Convert.ToInt32(page))
            {
                PageDdl.SelectedItem.Value = page;
            }
        }
    }
}

protected void PageDdl_SelectedIndexChanged(object sender, EventArgs e)
{
    Response.Redirect("report.aspx?proc=" + proc + "&page=" + PageDdl.SelectedItem.Text);
}

我的aspx:

        <div class="totalPages">   
            <asp:DropDownList ID="PageDdl" runat="server" 
                onselectedindexchanged="PageDdl_SelectedIndexChanged" 
                AutoPostBack="True" Visible="True">
            </asp:DropDownList>
        </div>
        Page: <%=page %>

在我的aspx上,顯示頁面變量,因此我可以確認其分配正確。

每次加載頁面時都會清除ViewState。 即使重新加載頁面也要保留它,而是將其存儲在Session中。 另外,您的Page_Load每次都會覆蓋它。 所以,是的,您將其存儲在ViewState中,但是也許您想檢查它是否在ViewState中而不要覆蓋它?

您可以在for循環內的1行設置所選值:

for (int i = 1; i <= totalPages; i++)
{
    PageDdl.Items.Add(new ListItem() { Text = i.ToString(), Selected = i == Convert.ToInt32(page) });
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM