+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 91.78 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

jQuery плагин для обработки событий online/offline в IE 8

06.11.2009 12:04

Итак, мне понадобилась поддержка событий online/offline в браузерах(напомню, что согласно черновику html5 они возникают при появлении/исчезновении соединения соответственно). На данный момент Mozilla и IE8 эти события поддерживают. А это уже немало.

Все бы хорошо, но online событие на 100% не гарантирует, что пользователь в онлайне. Оно гарантирует, что есть какое-то соединение, но не связь с интернетом. Поэтому необходима дополнительная проверка на доступность внешнего мира. Событие offline гарантирует, что связи нет, что может быть удобно в некоторых случаях, никаких дополнительных действий разработчику совершать не надо.

Не думаю, что со временем реализация этих событий изменится, поэтому если мы хотим точно знать, есть связь или нет, необходимо дописывать реализацию самим.

С Мозиллой и ие8 определились(все хорошо, но необходимо чуть подпилить), но что же делать с остальными браузерами, где еще нет этих событий? Будем определять их сами при инициилизации страницы и после аякс запросов. А сделаем это помощью jquery c trigger/bind в виде плагина.

Основные идеи плагина

0) Удобный интерфейс.
$(document.body).bind('xonline', function(event) { ... });
$(document.body).bind('xoffline', function(event) { ... });
Я использую xonline, xoffline так как online и offline уже реализованы в браузере, а мы, по сути, делаем надстройку над этими событиями.

1) Естественно, плагин должен поддерживать online, offline events для браузеров, в которых эти события имеются. При online для этих браузеров происходит дополнительная проверка на связь с интернетом. При offline ничего не проверяем.

2) Для браузеров, неподдерживающих эти действия, проверка на изменение сетевого статуса происходит после ajax запросов. Предположим, было соединение, а запрос оказался неудачным. В этом случае делаем дополнительную проверку на связь как в 1 пункте и, если надо, запускаем trigger('xoffline').

Как использовать?

Все просто, создаем обработчиков двух событий xonline, xoffline. Все остальное плагин выполнит сам. Посмотреть, как работает плагин, можно открыв пример, а затем отключившись от сети. В восьмом ie и firefox 3.5 сработает xoffline и прямоугольник перекрасится. В google chrome, opera, safari и ранних версиях ie и mozilla, помимо отключения от сети, для запуска события offline еще нужно выполнить неудачный запрос. Если жизненно необходимо следить за соединением постоянно, то плагин поддерживает метод $.checkWebstatus(time) (time - количество секунд). Этот метод в браузерах, неподдерживающих нативно online/offline события, проверяет каждые time секунд соединение. Пример с checkWebStatus

Успешно протестировано в Mozilla 3.5.3, IE8, IE6, Chrome, Opera 10

Update 10.10.2009
Подправил плагин:
1) Исправлен баг с проверкой состояния сети при оффлайне.
2) События переименованы из xonline, xoffline в более понятные trueonline, trueoffline.
3) Убраны методы и переменные из window.
4) Добавлена возможность настройки плагина.
6) Теперь он называется TrueOnline plugin :)

Всем спасибо за мудрые советы и тестирование

Скачать плагин 

Ссылки по теме

Файлы

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

На протяжении многих лет интернет-магазин предлагает товары и услуги, ориентированные на бизнес-пользователей и специалистов по информационным технологиям.

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

В нашем магазине вы можете приобрести лицензионное ПО выбрав необходимое из широкого спектра и ассортимента по самым доступным ценам. Наши менеджеры любезно помогут определиться с выбором ПО, которое необходимо именно вам. Также мы проводим учебные курсы. Мы приглашаем к сотрудничеству учебные центры, организаторов семинаров и бизнес-тренингов, преподавателей. Сфера сотрудничества - продвижение бизнес-тренингов и курсов обучения по информационным технологиям.



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года