У ViewState
страницы ASP.NET, похоже, есть проблемы с динамически удаленными элементами управления и значениями в них.Элементы управления ViewState и динамически удалены
Давайте возьмем следующий код в качестве примера:
ASPX:
<form id="form1" runat="server">
<div>
<asp:Panel runat="server" ID="controls" />
</div>
</form>
CS:
protected void Page_Init(object sender, EventArgs e) {
Button b = new Button();
b.Text = "Add";
b.Click +=new EventHandler(buttonOnClick);
form1.Controls.Add(b);
Button postback = new Button();
postback.Text = "Postback";
form1.Controls.Add(postback);
}
protected void Page_Load(object sender, EventArgs e) {
if (ViewState["controls"] != null) {
for (int i = 0; i < int.Parse(ViewState["controls"].ToString()); i++) {
controls.Controls.Add(new TextBox());
Button remove = new Button();
remove.Text = "Remove";
remove.Click +=new EventHandler(removeOnClick);
controls.Controls.Add(remove);
controls.Controls.Add(new LiteralControl("<br />"));
}
}
}
protected void removeOnClick(object sender, EventArgs e) {
Control s = sender as Control;
//A hacky way to remove the components around the button and the button itself
s.Parent.Controls.Remove(s.Parent.Controls[s.Parent.Controls.IndexOf(s) + 1]);
s.Parent.Controls.Remove(s.Parent.Controls[s.Parent.Controls.IndexOf(s) - 1]);
s.Parent.Controls.Remove(s.Parent.Controls[s.Parent.Controls.IndexOf(s)]);
ViewState["controls"] = (int.Parse(ViewState["controls"].ToString()) - 1).ToString();
}
protected void buttonOnClick(object sender, EventArgs e) {
if (ViewState["controls"] == null)
ViewState["controls"] = "1";
else
ViewState["controls"] = (int.Parse(ViewState["controls"].ToString()) + 1).ToString();
controls.Controls.Add(new TextBox());
}
Тогда, скажем создать 4 управления и вставьте следующие значения:
[ 1 ] [ 2 ] [ 3 ] [ 4 ]
Мы хотим удалить второй элемент управления; после удаления второго управления выхода:
[ 1 ] [ 3 ] [ 4 ]
который, что мы хотим. К сожалению, в последующем PostBack, список становится:
[ 1 ] [ ] [ 3 ]
Итак, мой вопрос, почему это происходит? Насколько я читал, ViewState
должен сохранять свойства элементов управления в зависимости от их индексов, а не от фактических элементов управления.
у меня есть связанный проблема - у меня есть GridView зависит от комбо постбэка. Когда вы меняете комбо, сетка обновляется с данными для нового значения комбо. Но если вы нажмете обновление, сетка вернется к данным по умолчанию для первого элемента в комбо, но комбо сбрасывается на элемент, который был выбран при обновлении, поэтому сетка и комбо не синхронизированы. Я попытался привязать и установить комбо для первого элемента в 'Page_Load if! Postback', а html показывает, что верхний элемент украшен' selected = "selected" ', но некоторые javascript затем меняют его на нестандартный пункт! Связано ли это? – Chris