Для примера создайте Web-узел, содержащий один элемент управления TextBox (с именем txtAutoPostback) и один ListBox (с именем lstTextBoxData). Затем обработайте событие TextChanged элемента TextBox и в серверном обработчике события добавьте в ListBox текущее значение TextBox (уследили за идеей?).
protected void txtAutoPostback_TextChanged(object sender, EventArgs e) {
lstTextBoxData.Items.Add(txtAutoPostback.Text);
}
Если выполнить приложение в таком виде, вы обнаружите, что в процессе ввода в TextBox ничего не происходит. Более того, ничего не произойдет и после ввода в TextBox при переходе к следующему элементу управления по нажатию клавиши табуляции. Причина в том, что свойство AutoPostBack типа TextBox по умолчанию имеет значение false. Но если установить для этого свойства значение true, как показано ниже:
‹asp:TextBox ID="txtAutoPostback" runat="server" AutoPostBack="True"OnTextChanged="txtAutoPostback_TextChanged"›
‹/asp:TextBox›
то вы увидите, что при выходе из TextBox по нажатию клавиши табуляции (или при нажатии клавиши ‹Enter›), ListBox автоматически получает текущее значение из TextBox. Без сомнения, кроме случая добавления данных одного элемента управления в другой, необходимости изменения состояния свойства AutoPostBack в других случаях не возникает.
Тип System.Web.UI.Control
Базовый класс System.Web.UI.Control определяет различные свойства, методы, и события, которые позволяют взаимодействовать с базовыми членами Web-элемента управления (обычно не относящимися к графическому интерфейсу). В табл. 23.9 предлагаются описания некоторых таких членов.
Таблица 23.5.Подборка членов System.Web.UI.Control
Член |
Описание |
Controls |
Свойство, получающее объект ControlCollection, представляющий дочерние элементы управления в рамках данного элемента управлений |
DataBind() |
Метод, выполняющий привязку источника данных к вызванному серверному элементу управления и всем его дочерним элементам управления |
EnableTheming |
Свойство, указывающее возможность поддержки тем для данного элемента управления |
HasControls() |
Метод для определения наличия дочерних элементов управления у данного серверного элемента управления |
ID |
Свойство, читающее или устанавливающее значение программного идентификатора для серверного элемента управления |
Page |
Свойство, получающее ссылку на экземпляр типа Page, содержащий серверный элемент управления |
Parent |
Свойство, получающее ссылку на родительский элемент управления данного серверного элемента управления в иерархии элементов управления страницы |
SkinID |
Свойство, читающее или устанавливающее параметры скиннинга элемента управления. Это дает возможность в ASP.NET 2.0 устанавливать внешний вид элемента управления динамически |
Visible |
Свойство, читающее или устанавливающее значение, указывающее необходимость обработки серверного элемента управления, как элемента пользовательского интерфейса страницы |
Список вложенных элементов управления
Первой из рассматриваемых здесь Особенностей System.Web.UI.Control является то, что все Web-элементы управления (это также относится и к Page) наследуют коллекцию пользовательских элементов управления (доступную с помощью свойства Controls). Во многом аналогично случаю приложений Windows Forms, в данном случае свойство Controls обеспечивает доступ к строго типизованной коллекции объектов WebControl. Подобно любой коллекции .NET, вы имеете возможность динамически добавлять и удалять элементы этой коллекции в среде выполнения.
Хотя добавлять Web-элементы управления в Page-тип можно и непосредственно, намного проще (и безопаснее) использовать для этого элемент управления Panel. Класс System.Web.UI.WebControls.Panel представляет контейнер элементов управления, который может быть видимым или невидимым для конечного пользователя (в зависимости от значений свойств Visible и BorderStyle).
Для примера создайте новый Web-узел с названием DynamicCtrls. В окне проектирования Web-страницы Visual Studio 2005 добавьте тип Panel (назначив ему имя myPanel), содержащий элементы TextBox, Button и HyperLink с произвольными именами (учтите, что режим проектирования требует, чтобы при перетаскивании внутренние элементы помещались в зону интерфейса типа Panel). В результате элемент ‹form› вашего файла *.aspx должен принять следующий вид.
‹asp: PanelID="myPanel" runat="server" Height="50px" Width="125px"›
‹asp: TextBoxID="TextBox1" runat="server"›‹/asp:TextBox›‹br /›
‹asp: ButtonID="Button1" runat="server" Text="Кнопка" /›‹br /›
‹asp: HyperLinkID="HyperLink1" runat="server"›Гиперссылка‹/asp:HyperLink›
Читать дальше