【发布时间】:2015-04-23 20:39:32
【问题描述】:
我有一个从数据库查询中获取正确值的页码下拉列表。除了我似乎无法弄清楚如何在下拉列表中保留所选值外,此列表的一切正常。页码通过查询字符串传递,我将其保留为 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 上,显示了 page 变量,因此我可以确认它已正确分配。
【问题讨论】:
-
你能定义“何时加载新页面”吗?您的意思是他们点击您页面上的按钮(回发)还是从头开始重新加载您的页面(例如按 F5?)
-
我已经编辑了你的标题。请参阅“Should questions include “tags” in their titles?”,其中的共识是“不,他们不应该”。