Различия
Здесь показаны различия между двумя версиями данной страницы.
Предыдущая версия справа и слева Предыдущая версия Следующая версия | Предыдущая версия | ||
comet:faq:realtime-users-list [2016/10/18 15:56] levhav |
comet:faq:realtime-users-list [2018/08/08 04:20] levhav [Подписка на обновление списка пользователей онлайн] |
||
---|---|---|---|
Строка 1: | Строка 1: | ||
+ | <rst>RU::12-Примеры::Как реализовать список посетителей обновляющийся на "лету"?</rst> | ||
+ | <rst>Header: Как реализовать список посетителей обновляющийся на лету</rst> | ||
+ | |||
====== Как реализовать список посетителей обновляющийся на "лету"? ====== | ====== Как реализовать список посетителей обновляющийся на "лету"? ====== | ||
Есть несколько возможных вариантов реализации. | Есть несколько возможных вариантов реализации. | ||
- | Можно получить из комет сервера список авторизованных пользователей подписанных на какой то из каналов. | + | Можно получить из комет сервера список авторизованных пользователей подписанных на какой-то из каналов. |
- Пользователь проходит [[comet:authentication|авторизацию на комет сервере]] | - Пользователь проходит [[comet:authentication|авторизацию на комет сервере]] | ||
Строка 9: | Строка 12: | ||
- Вы запросом к CometQL api получаете [[comet:cometql#таблица_users_in_pipes|список авторизованных пользователей подписанных на канал]] (это уже список кто сейчас онлайн) | - Вы запросом к CometQL api получаете [[comet:cometql#таблица_users_in_pipes|список авторизованных пользователей подписанных на канал]] (это уже список кто сейчас онлайн) | ||
- | - Чтобы список пополнялся новыми пользователями в режиме реального времени то надо в js добавить обработчики на события subscription и unsubscription приходящие из канала track_online (или того на какой вы подписались) | + | - Чтобы список пополнялся новыми пользователями в режиме реального времени, то надо в js добавить обработчики на события subscription и unsubscription приходящие из канала track_online (или того на какой вы подписались) |
- | Получение списка пользователей онлайн | + | ===== Получение списка пользователей онлайн ===== |
+ | Запросом к CometQL api получаете [[comet:cometql#таблица_users_in_pipes|список авторизованных пользователей подписанных на канал]] | ||
<code> | <code> | ||
mysql> SELECT * FROM users_in_pipes WHERE name = "track_online"; | mysql> SELECT * FROM users_in_pipes WHERE name = "track_online"; | ||
Строка 17: | Строка 21: | ||
- | Подписка на обновление списка пользователей онлайн | + | ===== Подписка на обновление списка пользователей онлайн ===== |
<code JavaScript> | <code JavaScript> | ||
CometServer().subscription("track_online.subscription", function(msg) | CometServer().subscription("track_online.subscription", function(msg) | ||
Строка 28: | Строка 32: | ||
}); | }); | ||
</code> | </code> | ||
+ | |||
+ | Пример: | ||
+ | <html> | ||
+ | <iframe height='600' scrolling='no' title='CppComet auth chat example' src='//codepen.io/Levhav/embed/zLJarm/?height=265&theme-id=0&default-tab=js,result&embed-version=2' frameborder='no' allowtransparency='true' allowfullscreen='true' style='width: 100%;'>See the Pen <a href='https://codepen.io/Levhav/pen/zLJarm/'>CppComet auth chat example</a> by Trapenok Victor (<a href='https://codepen.io/Levhav'>@Levhav</a>) on <a href='https://codepen.io'>CodePen</a>. | ||
+ | </iframe> | ||
+ | </html> | ||
+ | |||
+ | |||
+ | Пример отключения от комет сервера при потере фокуса окном. И подключении к комет серверу при получении фокуса. События подключения и отключения генерируют события в канале track_online у всех кто на этот канал подписан. | ||
+ | |||
+ | <html> | ||
+ | <iframe height='600' scrolling='no' title='QBZqYQ' src='//codepen.io/Levhav/embed/QBZqYQ/?height=265&theme-id=0&default-tab=js,result&embed-version=2' frameborder='no' allowtransparency='true' allowfullscreen='true' style='width: 100%;'>See the Pen <a href='https://codepen.io/Levhav/pen/QBZqYQ/'>QBZqYQ</a> by Trapenok Victor (<a href='https://codepen.io/Levhav'>@Levhav</a>) on <a href='https://codepen.io'>CodePen</a>. | ||
+ | </iframe> | ||
+ | </html> | ||
+ |