Javascript XMLHttpRequest, история создания, правила, примеры
Опубликованно 28.02.2019 00:18
XMLHttpRequest (XHR) - это API-в форме объекта, предоставленного в среде JavaScript в браузере. В частности, поиск данных XHR, с тем, чтобы изменить постоянно загруженной веб-страницы на основе дизайн-концепции Ajax. Несмотря на свое название, XHR, можно использовать протоколы, отличные от HTTP, и данные могут быть в форме не только XML и JSON, HTML или простой текст. Приложение поддерживает стандарт XHR. Текущая работа в W3C для создания стабильной спецификации основан на одном из снимков стандарта приложение.
Изначально Javascript XMLHttpRequest был объектом ActiveX, его использование ограничивалось интрасетей на основе Microsoft и не подходят с других сайтов. Команда Mozilla, был заинтересован в осуществлении эквивалент JScript и распространяться на всех браузерах, в том числе и тех, которые работают на базе Gecko / KHTML и Opera. Даже IE7 уже не требует установки ActiveX для использования XHR. История XMLHttpRequest
Понятие XMLHttpRequest Javascript создано специалистами Outlook Web Access для реализации на сервере Microsoft Exchange 2000. Версии 5 и 6 не определяли идентификатор объекта XHR в своих языках сценариев, поскольку один и тот же код Запроса не была стандартной в момент выброса. Microsoft добавила идентификатор объекта, в их языках сценариев в Internet Explorer 7.0, выпущенный в октябре 2006 года. В окне проекта был разработан и реализован интерфейс Javascript XMLHttpRequest механизм состав Gecko.
Он был разработан таким образом, чтобы максимально быть похожим на интерфейс Microsoft Request. Mozilla создала контейнер для использования этого интерфейса, через объект JS, который был под названием XMLHttpRequest. Объект уже была доступна в Gecko версии 0.6, опубликованном 6 декабря 2000 года, но еще не был полностью функциональным до 5 июня 2002 года, не вышла версия 1.0 Gecko, после того, как идентификатор объекта стала стандартом де-факто в других крупных веб-систем: Safari 1.2, опубликованной в феврале 2004 года. Opera 8.0, опубликованный в апреле 2005 года. iCab 3.0b352, опубликованном в сентябре 2005 года.
С появлением кросс-браузер библиотек JavaScript, таких как jQuery, разработчики могут вызывать функции Javascript XMLHttpRequest без кодирования, непосредственно, в API. World Wide Web Consortium опубликовал проект спецификации для XMLHttpRequest 5 апреля 2006 года, с целью документирования минимальный набор функций, совместимых с базой существующих реализаций, что позволяет разработчикам использовать без кода платформы.
25 февраля 2008 года, W3C опубликовал спецификацию рабочего проекта - XMLHttpRequest Level 2. Уровень 2 состоит из расширенной функциональностью, включая поддержку для запросов и обработки потоков байтов. Правила идентификации объекта
Учитывая, что стандарт W3C для объекта Javascript XMLHttpRequest post, еще вариант, пользовательские агенты не могут выполнить все функции определения, а любой трассировки может быть изменено. Осторожность, которую необходимо учитывать при написании сценария с помощью объекта XMLHttpRequest для нескольких агентов пользователя.
В HTTP и HTTPS запросов от объекта XMLHttpRequest, инициализируются открытым небом. Вызывается перед отправкой запроса для проверки. Этот метод не гарантирует, что URL-адрес существует, и информация пользователя является правильным. Это может занять до пяти параметров, но для инициализации запроса требуется только два. Первый параметр-это строка текста. Мы представляем метод запроса, который должен храниться у агента пользователя, проект W3C для Javascript XMLHttpRequest. Примеры: GET поддерживается Internet Explorer 7, Mozilla. POST поддерживается IE7, Mozilla. HEAD поддерживается IE7.
Методы поиска не ограничиваются перечисленными выше. В проекте W3C говорит, что браузер можно использовать по своему усмотрению.
Второй параметр-это строка текста, которая задает URL-адрес, HTTP-запроса.
Третий параметр-это логическое значение, которое указывает, является ли запрос асинхронным. Он не является обязательным в рамках проекта W3C. Значение по умолчанию должно считаться истинной, с помощью пользовательского агента W3C.
Асинхронный запрос "правда" не будет ждать ответа от сервера, прежде чем продолжить выполнение скрипта. Вместо этого, возникнет детектор событий onreadystatechange объекта XMLHttpRequest Javascript post на различных этапах запроса.
Четвертый и пятый параметры-это имя пользователя и пароль. Эти параметры могут быть использованы для аутентификации и авторизации, если необходим для сервера. Метод SetRequestHeader
После успешной инициализации можно вызвать метод Header объекта XMLHttpRequest open Javascript, чтобы отправить HTTP-заголовки запроса. Первый параметр метода-это имя заголовка. Второй параметр-это значение из строки текста. Этот метод должен быть использован для каждого заголовка, который отправляется в запросе.
"Скрытый камень" в XMLHttpRequest стандарт, который упрощает процесс отбора и анализа данных JSON через Ajax, JSON & JSON-p Обычный, чтобы предоставить данные сервера для браузеров, которые могут использоваться в клиентском JavaScript, это формат данных, таких как JSON, и доступа к ним через собственный URL-адрес. Например: XMLHttpRequest Javascript Json
Чтобы отправить HTTP-запрос, необходимо вызвать метод отправки XMLHttpRequest.
Firefox 3.0.x и более ранних версиях генерирует исключение, если send вызывается без аргументов. Если этот параметр-это объект DOM документа, агент пользователя должен гарантировать, что превращается в хорошо сформированный XML.
Если заголовок запроса Content-Type еще не добавлен через SetRequestHeader, автоматически должен добавляться соответствующий агента пользователя, таким действием: "application / xml; charset = charset ", где charset-кодировка, которая используется для документа. Если агент пользователя настроена на использование прокси-сервера, объект XMLHttpRequest изменится запрос для отправки Proxy-Authorization настроенных титров. Изменения состояния XHR
Если метод был вызван успешно, свойства объекта XMLHttpRequest присваивается значение 1 (Open). После того, как заголовки HTTP-ответа, вы получили, чтобы свойство readyState объекта XHR присваивается значение 2 (HEADERS_RECEIVED). После загрузки содержимое HTTP-ответа на свойство readyState объекта XHR должен быть установлен в значение 3 (Loading).
После завершения загрузки HTTP-ответа, чтобы свойство readyState объекта XHR, должен иметь значение 4 (Done). Студент будет реагировать только на изменения состояния, которые происходят после их определения. Для определения состояния 1 и 2, студент должен быть определен до вызова open. Открытый метод должен быть применен до вызова send.
Этот метод отменяет запрос, если объект readyState объекта XHR еще не было 4 (Done). Метод abort гарантирует, что обработчик обратного вызова не будет вызвана во время асинхронного запроса. Некоторые библиотеки AJAX используют прерывания, чтобы отменить потенциал, чтобы удвоить или уничтожены заявок. Кросс-доменные запросы
В ранней истории развития Интернета, обнаружил, что может поставить под угрозу безопасность пользователей JavaScript для обмена информацией с веб-сайта на другой, не менее хорошей репутацией. Таким образом, все современные браузеры реализуют одну и ту же политику происхождения, который останавливает многих атак, таких, как скрипты сайтов.
Данных Javascript XMLHttpRequest onload подвержены этой политики безопасности, но иногда веб-разработчики намеренно хотят обойти ограничения. Это связано с законным использованием поддоменов, поскольку создание XHR от страницы, созданной foo.example.com чтобы получить от него информацию bar.example.com как правило, неудачей.
Есть несколько альтернатив, чтобы избежать данной функции безопасности, включая использование JSONP, совместного использования ресурсов (CORS) или варианты с плагинами как Flash или Silverlight. Программы в браузерах
Инициализация объекта XHR-это на самом деле довольно проста, в большинстве браузеров, но для поддержки MSIE 5 и 6, должен учитывать несколько различных методов, таким образом, процесс является настолько сложным. В целом, сценарий пытается постоянно использовать три различных метода, пока он не состоится или не будет в конечном итоге.
Функция loadXMLDoc принимает два параметра. Первый из них-это местоположение скрипт на стороне сервера, и второй переменных, которые должны пройти этот сценарий.
Это краткий пример того, как можно назвать сценарий. Используется скрипт находится в /scripts/myscript.php с двух GET-параметры (q и target). Рекомендуется явно указывать значения с помощью encodeURIComponent. POST вместо GET
Для отправки на сервер данных из 512 байт, вы должны использовать POST или new XMLHttpRequest Javascript 34 Javascript, xml вместо GET. Если вы хотите получать данные для отправки, которые вы хотите изменить тип запроса, MIME, с помощью заголовка Content-Type и передачи переменных в вызове send. Заключительная часть функция loadXMLDoc изменяется, как показано на фото ниже.
В большинстве случаев, третий вариант, команда open может быть остановлен. Значение true указывает на то, что вызов должен быть асинхронным - сценарий продолжает, не дожидаясь ответа XML, что уже имеется по умолчанию. Передачи значение false, останавливает скрипт до получения ответа.
Сценарий, на который ссылается URL, будет скрипт на стороне сервера (PHP, Perl или подобных). Возвращается в хорошо сформированный XML-документ. Чтобы избежать предупреждения безопасности браузера, он должен быть помещен в том же домене, что наследодатель страницы, и быть доступной через HTTP или HTTPS. Передача JavaScript-сценария сервера
Функция, которая обрабатывает ответ (например, processReqChange), должен иметь возможность для извлечения и обработки XML. На этой диаграмме показано, как осуществляется передача данных из JavaScript сценария сервера, и наоборот.
Принцип довольно простой. Возвращаемый XML-документ будет содержать одну или несколько команд, которые выполняются последовательно для создания предупреждений, чтобы изменить значения, формы или управления ВС. Все это выполняется в функции processReqChange. Команды, доступные
В целом, применяются семь различных команд, которые могут быть вызваны библиотеки: alert (сообщение) - показать предупреждение JavaScript. setvalue (target value) - установить значение поля формы с идентификатором белый. значение setdefault (target) - сбросить значение поля формы. focus (target) – установить фокус на поле формы. setcontent (target, content) - установить HTML HTML-элемента. setstyle (target, property, value) - определение стиля элемента HTML. setproperty (target, property, value) - установить свойство элемента HTML.
В каждом случае цель-это идентификатор, который ссылается на элемент HTML-страницы. Другие значения текста или HTML, чтобы добавить дополнительные параметры функции processReqChange. Генерация XML-ответ с помощью PHP
Здесь представлены функции, которые предназначены для PHP программистов, которые не хотят слишком много знать о JavaScript, потому что после отправки первоначального запроса будущее JScript не нужно. XML-файл генерируется предупреждающее сообщение, например, для случая, когда, нажав на ссылку ниже, создается окно с предупреждением JS с текстом "hello world!") это важный первый шаг в любом языке программирования.
Следующий XML-ответ скачает немного текста в элемент на странице. В этом случае вывод, которое имеет идентификатор 2, будет отображаться в div. Вместо div, можно легко установить содержимое заголовка, абзаца или ячейки таблицы: example2 "hello world".
Как уже упоминалось выше, вы можете вставить HTML, а не текст, как вернуть динамические, а не статические. Следующий XML-запрос генерируется с использованием PHP, чтобы вставить текущую дату и время.
Internet Explorer сохраняет в кэше XML-ответ и использовать его для консультаций в будущем. Это означает, что вывод о том, что никогда не изменится. Другие браузеры каждый раз называют новый запрос.
Все браузеры с поддержкой DOM принимают backgroundColor, потому что имя стиля имеет цвет фона, который является более "правильным" и работает только в некоторых из них. Значения могут быть сгенерированы "на лету" с использованием PHP или на другом сервере. Первая команда устанавливает свойство background-color в диалоговом hello world в желтый цвет (# ff0), и вторая-в случайном (красный, зеленый или синий). Команда, в целом, связаны с формированием поля - установка / сброс значений в поле и установить фокус. Они полезны для проверки формы на стороне сервера в режиме реального времени, когда вы хотите просматривать данные без перезагрузки текущей страницы. Создание XML с помощью JavaScript
Существует несколько различных способов, как вызвать функцию loadXMLDoc. Например, вы берете ссылку на форму в качестве первого параметра, а затем две дополнительные переменные.
Успех вызова loadXMLDoc возвращает значение "истина". OnSubmit обработчик будет возвращать "ложь". Ущерба для действия по умолчанию, будет представлен на событии, которое в противном случае вызвало бы форму. Приложение выполняется с помощью Ajax, так что браузеру не нужно загружать новую страницу. Плохой вызов loadXMLDoc возвращает значение "ложь". OnSubmit обработчик будет возвращать "истину" и, соответственно, форму, будут представлены в нормальном режиме. Приложение, с помощью nonAjaxTarget.html.
Выполняется функция предотвращения кэширования значений ответа xmlhttprequest Javascript cookies. Некоторые браузеры будут кэшировать запросы GET, изготовленные с помощью XHR, что после первого вызова трассировки одной и той же последовательности команд, просто ты жесток первого ответа. Чтобы избежать этого, требуется добавить случайную строку или отметки времени запроса, как показано на фото ниже:
Если сценарий возвращает всегда один и тот же ответ для набор параметров, то нет необходимости беспокоиться об этом, потому что вы используете кэширование для ускорения приложения.
Короче говоря, насколько легко работать с Ajax с использованием этой структуры, только необходимо выполнить следующие действия: Настроить скрипт на стороне сервера, чтобы принимать параметры GET или POST или COOKIE-файлы и вернуть допустимый XML-файл. Указать файл xmlhttp.js JS на странице. Использовать JavaScript, чтобы позвонить.
Обратные вызовы Ajax можно сделать через создание экземпляра объекта XHR в клиенте JScript. Javascript XMLHttpRequest get можно использовать для прямого вызова серверных объектов, таких, как веб-страницы и услуг. Они собираются держать или возвращать данные.
Ajax было первоначально акронимом для асинхронный JS и XML. "Асинхронный" означает, что несколько событий происходят совершенно независимо друг от друга. Как только клиент входит в функцию обратного вызова Ajax для сервера, не нужно ждать ответ, потому что вы все еще можете использовать веб-приложения на момент запроса. После этого сервер отправляет ответ клиенту, и обрабатывать по мере необходимости. Автор: Иван Фролов 27 Ноября 2018 года
Категория: Новости Tech