本文以一个小例子简单的演示在微信小程序中使用环信SDK收发消息。
在WebIMConfig.js中将AppKey替换成自己应用的key
界面简单的用一个输入框和一个按钮组成,点击按钮发送消息。
导入WebIM.js
var WebIM = require('../../utils/WebIM.js')
var WebIM = WebIM.default
登陆
hxloign: function () {
var options = {
apiUrl: WebIM.config.apiURL,
user: 'u1',
pwd: 'p1',
grant_type: 'password',
appKey: WebIM.config.appkey //应用key
}
WebIM.conn.open(options)
},
发送文本消息
sendMessage: function () {
var that = this
var id = WebIM.conn.getUniqueId();
var msg = new WebIM.message('txt', id);
msg.set({
msg: this.data.inputValue,//输入框的文本
to: 'u0',
roomType: false,
success: function (id, serverMsgId) {
}
});
msg.body.chatType = 'singleChat';
WebIM.conn.send(msg.body);
},
接收消息
接收消息要先在app.js中添加回调函数
app.js获取聊天界面
getRoomPage: function () {
return this.getPage("pages/index/index")//聊天界面
},
getPage: function (pageName) {
var pages = getCurrentPages()
return pages.find(function (page) {
return page.__route__ == pageName
})
在app.jsonlanuch方法中进行声明
var that = this;
WebIM.conn.listen({
onTextMessage: function (message) {
var page = that.getRoomPage()
if (message) {
if (page) {
page.receiveMsg(message, 'txt')//receiveMsg方法就是咱在自己界面定义的方法
}else{
//界面不存在
}
}
}
})
index.js中定义的接收消息的方法
receiveMsg: function (msg, type) {
console.log(msg);
},