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

ЖАНРЫ

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

// Этот обработчик событий будет вызван несколько раз, по одному

// для каждой записи, соответствующей запросу, и еще один раз

// с пустым курсором, указывающим на окончание результатов,

var cursor = request.result // Курсор в свойстве

request.result if (!cursor) return; // Нет курсора = нет результатов

var object = cursor.value // Получить совпавшую запись

callback(object); //
Передать ее указанной функции

cursor.continue; // Запросить следующую запись

};

});

}

// Эта функция используется обработчиком onchange в документе ниже.

// Она выполняет запрос к БД и отображает результаты

function displayCity(zip) {

lookupCity(zip, function(s) { document.getElementById('city').value=s; });

}

// Это другая функция, используемая обработчиком onchange в документе ниже.

// Она выполняет запрос к БД и отображает результаты

function displayZipcodes(city) {

var output = document.getElementById("zipcodes");

output.innerHTML = "Найденные индексы:";

lookupZipcodes(city, function(o) {

var div = document.createElement("div");

var text = o.zipcode + ": + o.city + ", " + o.state;

div.appendChild(document.createTextNode(text));

output.appendChild(div);

});

}

// Настраивает структуру базы данных и заполняет ее данными, затем передает базу данных

// функции f. Эта функция вызывается функцией withDB, если база данных еще не была

// инициализирована. Это самая хитрая часть программы, поэтому мы оставили ее напоследок,

function initdb(db, f) {

// Загрузка информации о почтовых индексах и сохранение ее в базе данных может

// потребовать некоторого дополнительного времени при первом запуске этого

// приложения. Поэтому необходимо вывести сообщение, извещающее о выполнении операции,

var statusline = document.createElement("div");

statusline.style.cssText =

"position:fixed; left:0px; top:0px; width:100%;" +

"color:white; background-color: black; font: bold 18pt sans-serif;" +

"padding: 10px; ";

document.body.appendChild(statusline);

function status(msg) { statusline.innerHTML = msg.toString; };

status("Инициализация
базы данных почтовых индексов");

// Единственное место, где можно определить или изменить структуру

// базы данных IndexedDB - обработчик onsucess запроса setVersion.

var request = db.setVersion("1"); // Попробовать изменить версию БД

request.onerror = status; // Вывести сообщение в случае ошибки

request.onsuccess = function { // Иначе вызвать эту функцию

// База данных почтовых индексов включает единственное хранилище.

// Оно хранит объекты следующего вида: {

// zipcode: "02134", // Отправьте на телепередачу Zoom! [60] :-)

60

В 1972-1978 гг. телекомпания WGBH-TV в Бостоне выпускала детское телешоу «ZOOM». Детям предлагалось после шоу «выключить телевизор и сделать то, о чем рассказывалось в передаче...». Дети, обычно семеро, участвовавшие в шоу, играли в игры, ставили пьесы, рассказывали стихи, ставили научные эксперименты, вели беседы на такие темы, как больницы, предрассудки и другие, предлагаемые телезрителями. Передача имела призыв со словами: «Напишите на конверте ZOOM, Зет-Дабл-Оу-М, Бокс 3-5-0, Бостон, Масс 0-2-1-3-4 и отправьте его на ZOOM!». Весь текст проговаривался, кроме индекса, который пропевался. Описание в Википедии:(1972_TV_series).
– Прим, перев.

// city: "Allston",

// state: "MA",

// latitude: "42.355147",

// longitude: '-71.13164”

// }

//

// Свойство "zipcode" используется в качестве ключа базы данных

// Кроме того, создается индекс по названию города

// Создать хранилище объектов, указав имя хранилища и объект с параметрами,

// включающий "путь к ключу", определяющий имя свойства-ключа для этого

// хранилища. (Если опустить путь к ключу, IndexedDB определит свой

// собственный уникальный целочисленный ключ.)

var store = db.createObjectStore("zipcodes", // имя хранилища

Поделиться с друзьями: