有奖捉虫:办公协同&微信生态&物联网文档专题 HOT

功能描述

会话置顶,指的是把好友或者群会话固定在会话列表的最前面,方便用户查找。置顶状态会存储在服务器,切换终端设备后,置顶状态会同步到新设备上。
注意
置顶会话数上限50,不支持增加。

置顶会话

您可以调用 pinConversation(点击查看详情) 接口,设置是否置顶会话。
会话的顺序,按V2TimConversation 对象的 orderKey 字段排序。orderKey 字段是整型数,当发送新消息、接收新消息、设置草稿或置顶会话时,会话被激活,orderKey 字段会增大。
需要注意的是,被置顶会话始终排在非置顶会话的前面,如果同时置顶多个会话,这几个会话之间的相对顺序仍然会保持,例如,有 5 个依次排序的会话 1、2、3、4、5,同时置顶会话 2 和 3,置顶后的顺序是 2、3、1、4、5,显然,会话 2 和 3 排在最前面,并且会话 2 仍然排在 3 的前面。
调用 getConversationList 获取会话列表时,该接口会先返回置顶的会话,再返回未置顶的会话。您可以通过 V2TIMConversation 对象的 isPinned 字段,检查会话有没有置顶。
示例代码如下:
// isPinned 参数为 true,表示置顶会话,否则,表示取消置顶。
const isPinned = true;
conversationManager.pinConversation("conversationID", isPinned);

会话置顶变更通知

如果您事先调用了 addConversationListener(点击查看详情) 添加会话监听器,就可以在 onConversationChanged 中获取到 V2TimConversation 对象的 isPinned 字段值。根据这个字段可以判断会话的置顶状态是否变化。 示例代码如下:
conversationManager.addConversationListener({
onConversationChanged: (conversationList) => {
// 变更后的最新会话
},
});

交流与反馈

点此进入IM社群,享有专业工程师的支持,解决您的难题