Класс AjaxOptions
и его свойства используются во вспомогательных методах Ajax.BeginForm
и Ajax.ActionLink
для тонкой настройки асинхронного запроса и его параметров, а также действий, осуществляемых в ответ на изменение состояния запроса. Например, в следующием фрагменте кода AjaxOptions
используется для задания ряда параметров при вызове Ajax.ActionLink
:
function OnError() {
alert("Произошла ошибка!");
}
Нажмите на ссылку для получения времени<^span>
Вспомогательный метод Ajax.BeginForm
, в зависимости от реализации, содержит набор из следующих параметров:
□ actionName
— указывает наименование действия, которое следует вызвать в запросе, в случае, когда используется вариант метода без указания контроллера, вызывается действие контроллера текущего контекста;
□ controllerName
— указывает наименование контроллера (сокращенное, без суффикса Controller
), в котором следует искать и вызвать указанное в параметре actionName
действие;
□ routeValues
— указывает объект, содержащий параметры для механизма маршрутизации;
□ ajaxOptions
— указывает экземпляр класса AjaxOptions
с заданными свойствами, которые определяют параметры асинхронного запроса и могут определять ряд JavaScript-функций, реагирующих на изменение состояния запроса;
□ htmlAttributes
— набор значений пользовательских атрибутов для тега form
, которые должны быть помещены в разметку формы.
Ajax-расширения MVC Framework могут значительно облегчить работу по созданию Ajax-функционала как для форм, так и для простых запросов. Например, следующий код описывает создание простой Ajax-формы:
Введите логин и пароль, чтобы продолжить.
Введите логин:
Введите пароль:
Здесь с помощью вспомогательного метода Ajax.BeginForm
создается стандартная форма авторизации с двумя текстовыми полями для ввода логина и пароля и кнопкой отправки данных. Обратите внимание на параметры Ajax.BeginForm
: во-первых, указывается LoginForm
— наименование действия, которое должно вызваться в ответ на отправку данных с формы, во-вторых, с помощью класса AjaxOptions
задается специальный параметр UpdateTargetId
, который указывает на элемент, ответственный за отображение результата запроса. То есть, если запрос вернет данные, они будут отображены, в нашем случае, с помощью элемента span с идентификатором loginStatus
.
Как можно заметить, создание всего Ajax-функционала не потребовало у нас ни строчки JavaScript, не требуется от нас и понимание различий реализаций поддержки Ajax разными браузерами. Все это скрытно реализуют библиотеки MicrosoftAjax.js и MicrosoftMvcAjax.js, делая за разработчика всю рутинную работу по организации работы с асинхронными запросами. Если мы взглянем на исходный код, который сгенерирует подсистема Ajax в MVC Framework для нашего кода, то сможем убедиться, что генерируется достаточно много автоматического кода. Далее представлено определение формы, которое создано автоматически для нашего примера:
onclick="Sys.Mvc.AsyncForm.handleClick(this, new Sys.UI.DomEvent(event));"
onsubmit="Sys.Mvc.AsyncForm.handleSubmit(this,
new Sys.UI.DomEvent(event), {
insertionMode:Sys.Mvc.InsertionMode.replace,
updateTargetId:'loginStatus'
});">
Как можно видеть, вызов Ajax.BeginForm
сгенерировал код для функционала, который предлагают библиотеки MicrosoftAjax.js и MicrosoftMvcAjax.js.
Вспомогательный метод Ajax.ActionLink
, в зависимости от реализации, содержит набор из нескольких следующих параметров:
□ linkText
— текст, который будет рендериться в виде значения гиперссылки;
□ actionName
— указывает наименование действия, которое следует вызвать в запросе, в случае, когда используется вариант метода без указания контроллера, вызывается действие контроллера текущего контекста;
□ controllerName
— указывает наименование контроллера (сокращенное, без суффикса Controller
), в котором следует искать и вызвать указанное в параметре actionName
действие;
□ protocol
— указывает используемый для формирования ссылки протокол http или https;
□ hostName
— указывает значение хоста, которое будет использовано для формирования ссылки;
□ fragment
— указывает значение якоря, которое будет использовано для формирования ссылки. Это значение используется браузером для навигации по странице и обычно представляет собой значение идентификатора какого-либо элемента разметки, к которому следует выполнить навигацию. Данное значение будет добавлено к ссылке в следующем виде: http://localhost/Home/GetTime#fragment;
Читать дальше
Конец ознакомительного отрывка
Купить книгу