Web IM中桌面通知实战技巧
在实际使用的过程中,应该尽量减少通知功能对用户的干扰,最大程度的减少通知功能的出现,这就需要解决以下几个问题:
1. 收到多条消息时确保只出现一条通知;
2. 当用户处于IM出现的页面中时(页面处于Focus状态)将不出现通知;
3. 当用户使用多Tab开启多个存在IM的页面时,只要有一个页面处于Focus状态将不出现通知;
此外,还需要解决一个便利性问题
4. 如何让用户点击通知浮动层即可定位到具体的聊天窗口
1. 只弹出一个通知窗口
这个问题比较好解决,因为通知对象拥有一个名为"replaceId"的属性。指定该属性后,只要是相同replaceId的通知窗口弹出,都会覆盖之前弹出的窗口。在实际项目中是给所有的弹出窗口赋了一个相同的replaceId。不过需要注意的是,这种覆盖行为只在同域下有效。
2. 确保页面Focus时不弹出通知窗口
这个问题主要是在于判断浏览器窗口是否处于Focus状态,目前除了监听window的onfocus和onblur事件之外,貌似没有更好的方式。在项目中就是通过这种方式来记录窗口的Focus状态,然后当消息到达时根据Focus状态来判断是否弹出窗口。 使用该方法需要注意的地方是,事件注册的事件点应该尽可能的靠前,如果注册太晚则当用户打开页面后再离开就会很容易出现状态的误判。
3. 识别多Tab的Focus状态
多页面间的状态共享可以通过本地存储来实现:
浏览器窗口Focus时修改本地存储中指定key的值为"focus"
浏览器窗口Blur时修改本地存储中指定key的值为"blur"
需要注意的是,Chrome下从一个Tab切换到另一个Tab时,Blur有可能比Focus后写入存储中,因此修改Focus状态时需要异步处理。 实现以上状态共享后,新的消息到达后,只需要查看本地存储中’kxchat_focus_win_state’的值是否为blur,如果为blur才弹出窗口。
4. 通知窗口的事件响应
通知窗口支持onclick等事件响应,而响应函数中的作用范围属于创建该窗口的页面。如下代码: 在onclick的响应函数中访问的window对象即属于当前创建页面,因此可以很方便的与当前页面进行交互。以上代码便实现了点击弹出窗口会跳转到对应的浏览器窗口和打开IM窗口。 更多 0
- 华硕怎么win10系统(华硕如何装win10系统)
Win8 教程华硕怎么win10系统(华硕如何装win10系统)
华硕怎么装win10系统电脑用着用着,突然冒出些奇奇怪怪的毛病,例如运行卡顿、缓慢。这时候啊,重装系统可能就是你的救命稻草!虽然重装意味着你得和电脑上的所有数据暂时说拜拜,但它能让你的电脑焕然一新。想要轻松搞定?一键重装系统工具是你的不二之
- 怎么快速重装win10系统,如何快速重装win10系统
其它教程怎么快速重装win10系统,如何快速重装win10系统
怎么快速重装win10系统用着Win10,是不是偶尔会遇到系统卡顿、崩溃或者慢得像蜗牛爬?别担心,咱们有绝招,那就是重装系统。在线重装和U盘启动盘重装,哪个更简单?当然是在线重装啦,一键搞定,省心省力。只要提前做好数据备份,重要文件一个都不
- 01-24Win8 教程华硕怎么win10系统(华硕如何装win10系统)
- 01-24其它教程怎么快速重装win10系统,如何快速重装win10系统
- 01-24U盘教程怎么给电脑重装新版win10系统,如何给电脑重装新版win10系统
- 01-24安卓教程惠普电脑如何一键重装win7(一键重装win7系统方法)
- 01-24HarmonyOS教程如何一键重装电脑系统win7教程(一键重装电脑系统win7教程方法)
- 01-23苹果教程windows8如何重装系统 windows8重装系统教程
- 01-23Win8 教程华硕笔记本如何一键重装win10系统电脑装系统步骤