Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Работа в offline






Ещё одним несомненным преимуществом Application Cache является возможность работы в режиме offline. Только представьте себе – у клиента временно перестала работать сеть, но он всё равно может осуществлять работу с вашим ресурсом.
Но даже здесь не всё гладко. Вспомним одну особенность Application Cache – страница, на которой объявлен файл.manifest всегда попадает в кэш. В результате получается, что страница будет загружена, руководствуясь разделом CACHE, а не FALLBACK. То есть приложение будет вести себя, так как будто связь есть. Но как определить, что соединение отсутствует?
Для этого в спецификации HTML5 определенны два события online и offline, которые вызываются при создании и разрыве соединения соответственно. Как подсказал хабраюзер bolk, эти события работают в Safari 6 и Chrome 21. В остальных браузерах скорее всего они не реализованны.
Также можно воспользоваться свойством online объекта navigator:

 

window.navigator.onLine


Это свойство возвращает true при наличии соединение и false при его отсутствии. Получается, что при инициализации страницы нужно проверять это свойство и далее строить работу на основе его значения. На данный момент времени свойство navigator.onLine поддерживают браузеры Mozilla Firefox 2, Internet Explorer 4 и старше.
Пример использования:

 

<!DOCTYPE HTML><html lang="ru" manifest="cache.manifest"><head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Application Cache Test</title></head> <body><style> html {font-family: "DejaVu Sans", "Geneva CY", "Verdana"; background: #FFFFFF; OVERFLOW: hidden;; border: 0;} body {width: 880px; height: 600px; position: relative; background: #999999; margin: 20px auto; box-shadow: 0 0 15px 10px #999999; -webkit-box-shadow: 0 0 15px 10px #999999; -moz-box-shadow: 0 0 15px 10px #999999;} /* Экран загрузки*/.progressbar {display:none; position:absolute; left:0px; top:0px; width:880px; height:600px; background-color:#333333; z-index:256; border:1px solid #333333;}.progressbar #progresstext {position:absolute; left:0px; top:200px; width:880px; color:#66FF00; text-align:center; font-size:36px; text-shadow:0 0 0.8em #AAFF00, 0 0 0.8em #AAFF00;}.progressbar #progress {position:absolute; left:100px; top:300px; width:600px; height:40px;} /* Заставка */.flash {position:absolute; left:0px; top:0px; width: 880px; height: 600px; background-color:#666666; z-index:51; border: 1px solid #333333;}</style><!-- Блокирующее окно --><div id="flash" class="flash"></div><!-- Окно загрузки --><div id="progressbar" class="progressbar"><div id="progresstext">Загрузка</div><progress id="progress"></progress></div><script type="text/javascript" src="js/jquery-1.5.min.js"></script><script type="text/javascript"> // Переменные прогресса var progress_value = 0; var progress_max = 1; $(function() { // Проверяем подключение if (navigator.onLine) { alert('Соединение есть'); } else { alert('Невозможно установить соединение с сервером'); } // Получаем объект Application Cache cache = window.applicationCache; if (cache) { // Добавляем слушателей событий // Ресурсы уже кэшированнны. Индикатор прогресса скрыт. cache.addEventListener('cached', function(e) {ProgressHide();}, false); // Начало скачивания ресурсов. progress_max - количество ресурсов. Показываем индикатор прогресса cache.addEventListener('downloading', function(e) {ProgressShow(); progress_max = 3;}, false); // Процесс скачивания ресурсов. Индикатор прогресса изменяется cache.addEventListener('progress', function(e) {ProgressChange();}, false); // Скачивание ресурсов. Скрываем индикатор прогресса. Обновляем кэш. Перезагружаем страницу. cache.addEventListener('updateready', function(e) {ProgressHide(); window.applicationCache.swapCache(); location.reload();}, false); } }); // Отслеживаем нажатие клавиш клавиатуры $(document).keyup(function(event){ // При нажатии shift+1 производиться попытка обновления кэша if (event.shiftKey && event.keyCode == 49) { window.applicationCache.update(); } return false; }); //------------------- Функции управлением экраном загрузки ----------------// function ProgressShow() { $("#progressbar").show(300); progress_value = 0; } function ProgressChange() { progress_value++; $("#progress").attr({max: progress_max, value: progress_value}); } function ProgressHide() { $("#progressbar").hide(300); } //-------------------------------------------------------------------------//</script></body></html>

 








Дата добавления: 2015-08-12; просмотров: 441. Нарушение авторских прав; Мы поможем в написании вашей работы!




Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...


Картограммы и картодиаграммы Картограммы и картодиаграммы применяются для изображения географической характеристики изучаемых явлений...


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Метод архитекторов Этот метод является наиболее часто используемым и может применяться в трех модификациях: способ с двумя точками схода, способ с одной точкой схода, способ вертикальной плоскости и опущенного плана...

Примеры задач для самостоятельного решения. 1.Спрос и предложение на обеды в студенческой столовой описываются уравнениями: QD = 2400 – 100P; QS = 1000 + 250P   1.Спрос и предложение на обеды в студенческой столовой описываются уравнениями: QD = 2400 – 100P; QS = 1000 + 250P...

Дизартрии у детей Выделение клинических форм дизартрии у детей является в большой степени условным, так как у них крайне редко бывают локальные поражения мозга, с которыми связаны четко определенные синдромы двигательных нарушений...

Плейотропное действие генов. Примеры. Плейотропное действие генов - это зависимость нескольких признаков от одного гена, то есть множественное действие одного гена...

Методика обучения письму и письменной речи на иностранном языке в средней школе. Различают письмо и письменную речь. Письмо – объект овладения графической и орфографической системами иностранного языка для фиксации языкового и речевого материала...

Классификация холодных блюд и закусок. Урок №2 Тема: Холодные блюда и закуски. Значение холодных блюд и закусок. Классификация холодных блюд и закусок. Кулинарная обработка продуктов...

Studopedia.info - Студопедия - 2014-2026 год . (0.012 сек.) русская версия | украинская версия