здесь является критически важным (и мы увидим его неоднократно в этой главе), так как он дает указание IIS выполнить этот код на сервере, а не посылать его клиенту, предоставляя, тем самым, доступ к богатому окружению, рассмотренному ранее. Можно поместить наши функции, обработчики событий и т.д. в серверные блоки сценариев.
Если опустить атрибут
runat="server"
, мы, по сути, предоставим клиентский код,
который откажет, если он использует какое-либо кодирование в серверном стиле, которое мы увидим в этой главе. Однако могут возникать ситуации, когда понадобиться предоставить клиентский код (на самом деле ASP.NET сам иногда создает некий код в зависимости от возможностей браузера и используемого кода формы Web). К сожалению, мы не можем использовать здесь C#, так как это будет требовать платформы .NET на стороне клиента, что может не всегда существовать, поэтому JScript является, вероятно, лучшей возможностью (так как он поддерживается на большом множестве клиентских браузеров). Чтобы изменить язык, мы просто изменяем значение атрибута
language
следующим образом:
<script language="jscript">
// Клиентский код расположен здесь, можно также использовать vbscript.
</script>
В равной степени можно создавать файлы ASP.NET в Visual Studio, что прекрасно для нас подходит, так как мы уже знакомы с этой средой для программирования C#. Однако применяемая по умолчанию настройка проекта для приложений Web в этой среде предоставляет чуть более сложную структуру, чем один файл
.aspx
. Но это не является для нас проблемой, так как делает вещи более логичными (более подходящими для программиста и менее для разработчика Web). На основе этого в данной главе мы будем пользоваться Visual Studio.NET для программирования ASP.NET.
Рассмотрим пример. Создайте новый проект типа C# Type Web Application, как показано ниже:
По умолчанию VS будет использовать расширения FrontPage для настройки приложения Web в требуемом месте, которое может быть удаленным, если сервер Web находится на другой машине. Но и для этого существует альтернативный (и более быстрый) метод, использование файловой системы через LAN (что является, конечно, невозможным, если удаленный сервер Web находится не в той же LAN, что и сервер разработки). Если первый метод отказывает, то VS будет пробовать другой.
Независимо от используемого метода, VS поддерживает локальный кэш всех файлов проекта, причем в синхронизации с файлами на сервере Web.
Через какое-то время Visual Studio должна создать следующее:
□ Новое решение,
PCSWebAppl
, содержащее приложение Web на C# с именем
PCSWebAppl
□
AssemblyInfo.cs
— стандартный код для описания сборки
□
Global.asax
— глобальная информация и события приложения (будет показано позже в этой главе)
□
PCSWebAppl.disco
— файл, описывающий все службы Web в проекте, дающий возможность динамического обнаружения (подробности в следующей главе)
□
Web.config
— конфигурационная информация для приложения (будет показано позже в этой главе)
□
WebForm1.aspx
— первая страница ASP NET в приложении Web
Мы покажем все сгенерированные файлы в ходе изложения этой и следующих
двух глав, в данный момент нам необходимо сосредоточиться на сердцевине приложения — созданном файле
.aspx
.
Файлы
.aspx
можно просматривать двумя способами: в виде модели и в виде кода. Это аналогично тому, что используется для форм Windows, как мы видели раньше в этой книге. Начальное представление в VS является модельным представлением:
Текст, показанный здесь по умолчанию, не является текстом, который мы увидим в приложении, это просто примечание от VS, сообщающее, какой режим компоновки выбран. Здесь используется режим GridLayout, который допускает большую гибкость в управлении позиционированием, но можно сменить его на FlowLayout, если требуется более традиционная схема позиционирования типа HTML. Мы рассмотрим это немного позже.
Если выбрать представление HTML с помощью кнопки внизу окна компоновки, мы увидим код, созданный внутри файла
<meta name=vs_targetSchema content="Internet Explorer 5.0">
<meta name="GENERATOR" Content="Microsoft Visual Studio 7.0">
<meta name="CODE_LANGUAGE" Content="C#">
</head>
<body MS_POSITIONING="GridLayout">
<form method="post" runat="server">
</form>
</body>
</html>
Здесь элемент
<html>
заполнен несколькими метаданными, которые нас не касаются, и элементом
<form>
для размещения кода ASP.NET. Наиболее важной вещью в этом элементе является атрибут
runat
. Точно так же, как в блоках серверного кода, которые мы видели в начале раздела, он задан как server, и значит, обработка формы будет иметь место на сервере. Если не включить этот атрибут, то никакой серверной обработки выполняться не будет, и форма не будет ничего делать.
Другая интересная вещь в отношении этого кода состоит в теге
<@% Page %>
в начале файла. Этот тег определяет характеристики страницы, которые важны для нас как разработчиков приложения Web на C#. Прежде всего здесь существует атрибут
language
, который определяет, что на этой странице будет использоваться C#, как мы видели раньше в блоках
<script>
(значение по умолчанию для приложения Web является VB.NET, хотя это может быть изменено через конфигурацию IIS). Следующие три атрибута являются необходимыми, так как код, управляющий страницей, был задан VS для размещения в отдельном файле
WebForm1.aspx.cs
. Этот файл, который мы сейчас рассмотрим, содержит определение класса, используемого в качестве базового для страницы форм Web. (Теперь мы начинаем видеть, как ASP.NET соединяется с насыщенной объектной моделью). В этом файле для создания HTML базовый класс будет использоваться в соединении с кодом.