Другие высокоуровневые утилиты поддержки архитектуры Ajax в библиотеке jQuery являются функциями, а не методами и вызываются относительно глобального имени
jQuery
или
$
, а не относительно объекта с выбранными элементами. Функция
jQuery.getScript
загружает и выполняет файлы со сценариями на языке JavaScript. Функция
jQuery.getJS0N
загружает содержимое URL и разбирает его как текст в формате JSON, а получившийся в результате объект передает указанной функции обратного вызова. Обе эти функции вызывают функцию
jQuery.get
, которая является более универсальной функцией загрузки данных из указанного URL-адреса. Наконец, функция
jQuery.post
действует подобно функции
jQuery.get,
но выполняет HTTP-запрос методом POST, а не GET. Как и метод
load,
все эти функции выполняются асинхронно: они возвращают управление еще до того, как будут загружены какие-либо данные, и извещают программу о результатах посредством указанной функции обратного вызова.
19.6.2.1. jQuery.getScript
Функция
jQuery.getScript
принимает в первом аргументе URL-адрес файла со сценарием на языке JavaScript. Она асинхронно загружает и выполняет этот сценарий в глобальной области видимости. Выполняться могут сценарии как общего происхождения с документом, так и сторонние:
// Динамически загрузить сценарий с некоторого другого сервера
Во втором аргументе можно передать функцию обратного вызова, и в этом случае библиотека jQuery вызовет ее сразу после того, как загруженный сценарий будет выполнен.
// Загрузить библиотеку и воспользоваться ею после загрузки
jQuery.getScript("js/jquery.my_plugin.js", function {
Для получения текста сценария, который должен быть выполнен, функция
jQuery.getScript
обычно использует объект
XMLHttpRequest
. Но для выполнения междоменных запросов (когда сценарий поставляется сервером, отличным от того, откуда был получен текущий документ), библиотека jQuery использует элемент
<script>
(раздел 18.2). Если запрос удовлетворяет ограничениям политики общего происхождения, в первом аргументе функции обратного вызова передается текст сценария, во втором - код состояния «success» и в третьем - объект
XMLHttpRequest
, использовавшийся для получения текста сценария. Возвращаемым значением функции
jQuery.getScript
в данном случае также является объект
XMLHttpRequest
. Для междоменных запросов, которые выполняются без участия объекта
XMLHttpRequest
, текст сценария не сохраняется. В этом случае в первом и третьем аргументах функции обратного вызова передается значение undefined, и возвращаемым значением функции
jQuery.getScript
также является значение undefined.
Функция обратного вызова, передаваемая функции
jQuery.getScript,
вызывается только в случае успешного выполнения запроса. Если также необходимо получить извещение в случае ошибки, следует использовать низкоуровневую функцию
jQuery.ajax
. То же относится и к трем другим вспомогательным функциям, описываемым в этом разделе.
19.6.2.2. jQuery.getJSON
Функция
jQuery.getJSON
подобна функции
jQuery.getScript:
она загружает текст и затем обрабатывает его особым образом перед вызовом указанной функции обратного вызова. Функция
jQuery.getJSON
не выполняет загруженный текст как сценарий, а выполняет синтаксический разбор этого текста как данных в формате JSON (используя функцию
jQuery.parseJSON:
описывается в разделе 19.7). Функцию
jQuery.getJSON
имеет смысл использовать, только когда ей передается функция обратного вызова. Если содержимое URL было благополучно загружено и разобрано, как данные в формате JSON, то полученный в результате объект передается функции обратного вызова в первом
аргументе. Как и при использовании функции
jQuery.getScript
, во втором и третьем аргументах передаются код состояния «success» и объект
XMLHttpRequest
:
// Допустим, что data.json содержит текст: '{"х":11"у":2}'
jQuery.getJS0N("data.json", function(data) {
// Здесь data - это объект {x:1. у:2}
});
Передача данных утилитам поддержки Ajax в библиотеке jQuery
Большинство методов поддержки архитектуры Ajax в библиотеке jQuery принимают аргумент (или параметр), определяющий данные для отправки на сервер вместе с URL. Обычно эти данные принимают вид строки, закодированной в формате URL, пар имя/значение, отделяющихся друг от друга символами амперсанда. (Этот формат представления данных известен, как MIME-тип «application/x-www-form-urlencoded». Его можно рассматривать как аналог формата JSON - формата представления простых JavaScript-объектов в виде строк.) При выполнении HTTP-запросов методом GET эта строка с данными добавляется в конец URL-адреса запроса. При выполнении запросов методом POST она отправляется в теле запроса после отправки НТТР-заголовков.
Получить строку с данными в этом формате можно с помощью метода
serialize
объекта
jQuery
, содержащего формы или элементы формы. Отправить, например, HTML-форму с помощью метода load можно следующим образом:
$("#submit_button").click(function(event) {
S(this.form).load( // Заменить форму, загрузив...
this.form.action, // из указанного url
$(this. form). serialize); // с данными, добавленными в него
event.preventDefault: // Отменить отправку формы по умолч.
this.disabled = "disabled": // Предотвратить несколько
}); // попыток отправки
Если в аргументе (или параметре) передать функции поддержки архитектуры Ajax в библиотеке jQuery объект, а не строку, то библиотека jQuery по умолчанию (с исключениями, описываемыми ниже) автоматически преобразует объект в строку, вызвав функцию
jQuery.param
. Эта вспомогательная функция интерпретирует свойства объекта как пары имя/значение и, например, преобразует объект {х:1 ,у:'hello”} в строку "x=1&y=hello".
В версии jQuery 1.4 функция
jQuery.param
способна обрабатывать более сложные объекты. Если значение свойства объекта является массивом, для каждого элемента этого массива будет создана отдельная пара имя/значение, а к имени свойства будут добавлены квадратные скобки. Если значением свойства является объект, имена свойств этого вложенного объекта помещаются в квадратные скобки и добавляются к имени внешнего свойства. Например: