Чтение онлайн

на главную - закладки

Жанры

JavaScript. Подробное руководство, 6-е издание
Шрифт:

20.3. Механизм сохранения userData в IE

В IE версии 5 и ниже поддерживается механизм сохранения данных на стороне клиента, доступный в виде нестандартного свойства

behavior
элемента документа. Использовать его можно следующим образом:

var memory = document.createElement("div"); // Создать элемент

memory.id = "_memory”; // Дать ему имя

memory.style.display = "none"; // He отображать его

memory.style.behavior = "url('#default#userData')"; // Присоединить свойство

document.body.appendChild(memory); // Добавить в документ

После того как для элемента будет определено поведение «userData», он получает новые методы

load
и
save.
Вызов метода
load
загружает сохраненные данные. Этому методу можно передать строку, напоминающую имя файла и идентифицирующую конкретный пакет хранящихся данных. После загрузки данных пары имя/значение становятся доступны в виде атрибутов элемента, получить которые можно с помощью метода
getAttribute
. Чтобы сохранить новые данные, необходимо установить атрибуты вызовом метода
setAttribute
и затем вызвать метод
save.
Удалить значение можно с помощью методов
removeAttribute
и
save.
Ниже приводится пример использования элемента
memory
, инициализированного выше:

memory.load("myStoredData"); // Загрузить сохраненные данные

var name = memory.getAttribute("username"); // Получить элемент данных

if (!name) { // Если он не был определен,

name = prompt("Как вас зовут?); // запросить у пользователя

memory.setAtttribute("username", name); // Установить как атрибут

memory.save("myStoredData"); // И сохранить до следующего раза

}

По умолчанию данные, сохраняемые с помощью механизма

userData
, имеют неограниченный срок хранения и сохраняются до тех пор, пока явно не будут удалены. Однако с помощью свойства
expires
можно определить дату, когда истечет срок хранения данных. Например, в предыдущий фрагмент можно было бы добавить следующие строки, чтобы указать, что срок хранения данных истечет через 100 дней:

var now = (new Date).getTime; // Текущее время в миллисекундах

var expires = now + 100 * 24 * 60 * 60 * 1000; // + 100 дней в миллисекундах

expires = new Date(expires).toUTCString; // Преобразовать в строку

memory.expires = expires; // Установить срок хранения

Данные, сохраняемые с помощью механизма

userData
в IE, доступны только для документов, хранящихся в том же каталоге, что и оригинальный документ, сохранивший их. Это более ограниченная область видимости, чем у cookies, которые также доступны документам в подкаталогах оригинального каталога. В механизме
userData
отсутствует какой-либо эквивалент атрибутов
path
и
domain
в cookies, позволяющий расширить область видимости данных.

Механизм

userData
позволяет сохранять гораздо большие объемы данных, чем cookies, но меньшие, чем объекты
localStorage
и
sessionStorage
.

Пример 20.3 реализует методы

getltem, setltem
и
removeltem
интерфейса
Storage
поверх механизма
userData
в IE. (Он не реализует такие методы, как
кеу
и
clear
, потому что механизм
userData
не предоставляет возможность выполнять итерации по всем хранящимся элементам.)

Пример 20.3. Частичная реализация интерфейса

Storage
на основе механизма
userData
в IE

function UserDataStorage(maxage) {

// Создать элемент документа и установить в нем специальное

// свойство behavior механизма userData, чтобы получить доступ

// к методам save и load.

var memory = document.createElement("div"); // Создать элемент

memory.style.display = ''none"; // He отображать его

memory.style.behavior = "url('#default#userData')"; // Присоединить свойство behavior

document.body.appendChild(memory); // Добавить в документ

// Если указано значение параметра maxage, хранить данные maxage секунд

if (maxage) {

var now = new Date.getTime; // Текущее время

var expires = now + maxage * 1000; // maxage секунд от текущего времени

memory.expires = new Date(expires).toUTCString;

}

// Инициализировать хранилище, загрузив сохраненные значения.

// Значение аргумента выбирается произвольно, но оно должно совпадать

// со значением, переданным методу save

memory.load("UserDataStorage”); // Загрузить сохраненные данные

this.getltem = function(key) { // Загрузить значения атрибутов

return memory.getAttribute(key) || null;

};

Поделиться:
Популярные книги

Я уже царь. Книга XXIX

Дрейк Сириус
29. Дорогой барон!
Фантастика:
юмористическое фэнтези
аниме
попаданцы
5.00
рейтинг книги
Я уже царь. Книга XXIX

Подросток

Достоевский Федор Михайлович
Проза:
русская классическая проза
9.09
рейтинг книги
Подросток

Товарищ "Чума" 6

lanpirot
6. Товарищ "Чума"
Фантастика:
городское фэнтези
попаданцы
альтернативная история
5.00
рейтинг книги
Товарищ Чума 6

Сирийский рубеж 3

Дорин Михаил
7. Рубеж
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Сирийский рубеж 3

Локки 4 Потомок бога

Решетов Евгений Валерьевич
4. Локки
Фантастика:
аниме
фэнтези
5.00
рейтинг книги
Локки 4 Потомок бога

Алые перья стрел

Крапивин Владислав Петрович
Детские:
детские приключения
8.58
рейтинг книги
Алые перья стрел

Некромант

Щепетнов Евгений Владимирович
4. Петр Синельников
Фантастика:
боевая фантастика
6.20
рейтинг книги
Некромант

На границе империй. Том 10. Часть 5

INDIGO
23. Фортуна дама переменчивая
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
На границе империй. Том 10. Часть 5

Барон. Книга вторая

Первухин Андрей Евгеньевич
6. Ученик
Фантастика:
фэнтези
попаданцы
5.40
рейтинг книги
Барон. Книга вторая

Эфемер

Прокофьев Роман Юрьевич
7. Стеллар
Фантастика:
боевая фантастика
рпг
7.23
рейтинг книги
Эфемер

Майами

Фишер Марк
Детективы:
триллеры
6.40
рейтинг книги
Майами

Чужак

Листратов Валерий
1. Ушедший Род
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Чужак

Старая школа рул

Ромов Дмитрий
1. Второгодка
Фантастика:
альтернативная история
6.00
рейтинг книги
Старая школа рул

Требую развода! Что значит- вы отказываетесь?

Мамлеева Наталья
Любовные романы:
любовно-фантастические романы
5.00
рейтинг книги
Требую развода! Что значит- вы отказываетесь?