<MyRusakov.ru />

React JS, Redux, ES2015 с Нуля до Гуру

React JS, Redux, ES2015 с Нуля до Гуру

Данный курс - это обширный курс по JavaScript и фреймворку React, который позволит Вам с нуля создавать мощные современные, динамические JavaScript-приложения.

Вы узнаете о тонкостях работы с "профессиональным" JavaScript, а так же узнаете о нововведениях в его новый стандарт ES2015, Вы узнаете, как организовать профессиональное окружение для FrontEnd, изучите профессиональный фреймворк - ReactJS.

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

Подробнее
Подписка

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Каким движком Вы предпочитаете пользоваться?

Как определить, смотрит ли пользователь на страницу?

Как определить, смотрит ли пользователь на страницу?

Всем привет! Сегодня мы рассмотрим, как определить, смотрит ли пользователь на страницу?

Вы довольно часто могли видеть это функционал на сайтах. Два самых простых случая:

1) Если пользователь неактивен в течение какого-то времени, то он автоматически деавторизуется. Сделано для защиты аккаунта пользователя.

2) Если пользователь неактивен в течение какого-то времени, то он автоматически отключается от сервера и подключается к нему только тогда, когда снова станет активен. Удобно, чтобы не нагружать лишним соединением сеть и сервера. Используется в социальных сетях и других высоконагруженных проектах.

Кажется, что реализовать такой полезный функционал довольно трудно, однако это не так. Существует много разных библиотек, которые вы можете подключить и радоваться, но в этой статье мы не будем их использовать, а попробуем сделать все сами на чистом javascript. Уверяю вас, это не сложно!

Существует много самых разных реализаций, мы же будем использовать Page Visibility API.

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Как определить, активен ли пользователь?</title>
</head>
<body>
  <script>
   var pollCount = 1;

   var poll = function() {
   if(document.hidden) {
    return;
   }
    console.log('Опрошено ' + pollCount + 'раз');
    pollCount++;
   };

   setInterval(poll, 1000);
   document.addEventListener('visibilitychange', function() {
    console.log('Видимость изменена на ' + document.visibilityState + '!');
   });
  </script>
</body>
</html>

Теперь откройте консоль, посмотрите, что начался отсчет. Теперь перейдите на другую вкладку, а потом вернитесь. Вы увидите, что сначала видимость изменилась на hidden, а потом на visible.

Вот так просто вы можете отследить, смотрит ли пользователь на страницу.

Спасибо за внимание!

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (1):

(Алекс) (Алекс) 30.05.2015 22:26:22

хмм... очень интересно, спасибо, попробую)

Ответить

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.