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

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

Работа в 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Р,где...

Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит...

Кран машиниста усл. № 394 – назначение и устройство Кран машиниста условный номер 394 предназначен для управления тормозами поезда...

Приложение Г: Особенности заполнение справки формы ву-45   После выполнения полного опробования тормозов, а так же после сокращенного, если предварительно на станции было произведено полное опробование тормозов состава от стационарной установки с автоматической регистрацией параметров или без...

Тема 2: Анатомо-топографическое строение полостей зубов верхней и нижней челюстей. Полость зуба — это сложная система разветвлений, имеющая разнообразную конфигурацию...

Виды и жанры театрализованных представлений   Проживание бронируется и оплачивается слушателями самостоятельно...

Что происходит при встрече с близнецовым пламенем   Если встреча с родственной душой может произойти достаточно спокойно – то встреча с близнецовым пламенем всегда подобна вспышке...

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