更新时间:2023-04-10
实现方案:
文本消息新增扩展字段em_at_list
, 表示被@的用户ID,
const MENTION_ALL = 'ALL';
let mentionList = ['userId', 'userId1'];
let isMentionALl = true
let txt = {
to: 'groupId',
chatType: 'groupChat',
msg: '@user 你好',
type: 'txt',
ext: {
em_at_list: isMentionALl ? MENTION_ALL : atList
}
}
收到文本消息, 如扩展字段包含em_at_list
则表示为@消息,
如果em_at_list
包含当前用户,则进行UI更新
// onTextMessage回调中
let mentionList = message?.ext?.em_at_list
// 如果存在mentionList, 并且不是当前用户多端同步的消息
if(mentionList && message.from !== WebIM.conn.user){
// 如果是@所有人或者mentionList包含当前用户ID
if(mentionList === MENTION_ALL || mentionList.includes(WebIM.conn.user)){
// 则进行UI更新
}
}
更新时间:2022-07-15
环信即时通讯 WEB 端提供示例应用可供体验。为方便体验,建议使用你自己的 Demo 应用,具体步骤如下:
在 环信即时通讯云 IM 管理后台 通过邮箱注册,可以看到默认的 Demo 应用(默认应用是全功能开通的应用);
在上图页面 Demo 应用右侧点击 查看,选择 开放注册;
打开 Demo,点击 服务器配置;
将 Demo 的 App Key 填入,点击 保存配置;
然后点击 注册用户 进行体验。
注意
注册模式分两种,开放注册和授权注册。只有开放注册时,才可以客户端注册。
欢迎大家提交 PR 改进和修复 WebIM 中的问题。
从IM SDK 及 Demo 下载 下载 WEB SDK 压缩包,然后解压。解压后在 demo
文件夹下,即为 WebIM 的工程目录。
初始化安装
npm install
运行demo
cd demo && npm start
cd demo && HTTPS=true npm start
(webrtc supports HTTPS only)
Demo 中有几大模块