JavaScript. Подробное руководство, 6-е издание
Шрифт:
Свойство
location
объекта Document
также ссылается на объект Location
:
window.location === document.location // всегда верно
Кроме того, объект
Document
имеет свойство URL
, хранящее статическую строку с адресом URL документа. При перемещении по документу с использованием идентификаторов фрагментов (таких как «#table-of-contents») внутри документа объект Location
будет обновляться, отражая факт перемещения,
14.2.1. Анализ URL
Свойство
location
окна является ссылкой на объект Location
и представляет URL-адрес документа, отображаемого в данный момент в текущем окне. Свойство href
объекта Location
– это строка, содержащая полный текст URL-адреса. Метод toString
объекта Location возвращает значение свойства href
, поэтому в контекстах, где неявно подразумевается вызов метода toString,
вместо конструкции location.href
можно писать просто location
. Другие свойства этого объекта, такие как
protocol, host, hostname, port, pathname, search
и hash
, определяют отдельные части URL-адреса. Они известны как свойства «декомпозиции URL» и также поддерживаются объектами Link
(которые создаются элементами <а>
и <агеа>
в HTML-документах). Полное описание объектов Location
и Link
приводится в четвертой части книги. Свойства
hash
и search
объекта Location
представляют особый интерес. Свойство hash
возвращает «идентификатор фрагмента» из адреса URL, если он имеется: символ решетки (#) со следующим за ним идентификатором. Свойство search
содержит часть URL-адреса, следующую за вопросительным знаком, если таковая имеется, включая сам знак вопроса. Обычно эта часть URL-адреса является строкой запроса. В целом эта часть URL-адреса используется для передачи параметров и является средством встраивания аргументов в URL-адрес. Хотя эти аргументы обычно предназначены для сценариев, выполняющихся на сервере, нет никаких причин, по которым они не могли бы также использоваться в страницах, содержащих JavaScript-код. В примере 14.2 приводится определение универсальной функции urlArgs,
позволяющей извлекать аргументы из свойства search
URL-адреса. В примере используется глобальная функция decodeURIComponent,
имеющаяся в клиентском JavaScript. (Смотрите справочную статью «Global» в третьей части книги.) Пример 14.2. Извлечение аргументов из строки search URL-adpeca
/*
* Эта функция выделяет в URL-адресе разделенные амперсандами
* пары аргументов имя/значение из строки запроса. Сохраняет эти пары
* в свойствах объекта и возвращает этот объект. Порядок использования:
*
* var args = urlArgsO; // Извлечь аргументы из URL
* var q = args.q || "" // Использовать аргумент, если определен,
//
или значение по умолчанию
* var n = args.n ? parselnt(args.n) : 10;
*/
function urlArgs {
var args = {}; // Создать пустой объект
var query = location.search.substring(1); // Строка запроса без '?'
var pairs = query.split("&"); // Разбить по амперсандам
for(var і = 0; і < pairs.length; i++) { // Для каждого фрагмента
var pos = pairs[i].index0f('='); // Отыскать пару имя/значение
if (pos == -1) continue; // He найдено - пропустить
var name = pairs[i].substrings,pos); // Извлечь имя
var value = pairs[i].substring(pos+1); // Извлечь значение
value = decodeURIComponent(value); // Преобразовать значение
args[name] = value; // Сохранить в виде свойства
}
return args; // Вернуть полученные аргументы
}
14.2.2. Загрузка нового документа
Метод
assign
объекта Location
заставляет окно загрузить и отобразить документ по указанному URL-адресу. Метод replace
выполняет похожую операцию, но перед открытием нового документа он удаляет текущий документ из списка посещавшихся страниц. Когда сценарию просто требуется загрузить новый документ, часто предпочтительнее использовать метод replace,
а не assign.
В противном случае кнопка Back (Назад) броузера вернет оригинальный документ и тот же самый сценарий снова загрузит новый документ. Метод location.replace
можно было бы использовать для загрузки версии веб-страницы со статической разметкой HTML, если сценарий обнаружит, что броузер пользователя не обладает функциональными возможностями, необходимыми для отображения полноценной версии:
// Если броузер не поддерживает объект XMLHttpRequest, выполнить
// переход к статической странице, которая не использует его.
if (!XMLHttpRequest) location.replace("staticpage.html");
Примечательно, что строка URL-адреса в этом примере, переданная методу
replace,
представляет относительный адрес. Относительные URL-адреса интерпретируются относительно страницы, в которой они появляются, точно так же, как если бы они использовались в гиперссылке. Кроме методов
assign
и гер1асе
объект Location определяет также метод reload,
который заставляет броузер перезагрузить документ. Однако более традиционный способ заставить броузер перейти к новой странице заключается в том, чтобы просто присвоить новый URL-адрес свойству
location
:
location = '' http://www.oreilly.com "; // Перейти, чтобы купить несколько книг!
Поделиться с друзьями: