vue.js+socket.io+express+mongodb打造在线聊天[二]

在线地址观看

http://www.chenleiming.com/vuechat

github地址

https://github.com/clm960227/...

有喜欢的小哥哥,小姐姐请反手来个star,谢谢!有issue的欢迎提出

介绍
本项目基于vue.js+socket.io+express+mongodb实现的聊天效果, 界面以及功能参考QQ,微信

技术栈

  • 前端: vue,vue-router,vuex,axios
  • 构建: webpack,vue-cli
  • 后端: express,multer(上传图片),cors(跨域处理), superagent(调用机器人接口),mongoose(操作数据库)
  • 通讯: socket.io
  • 数据库: mongodb
  • css预处理器: sass

功能列表

  • 用户注册
  • 用户登录
  • 群聊
  • 群聊中@小美 和机器人聊天 (注意@小美和消息中间要有空格)
  • 机器人聊天
  • 留言板
  • 更换主题颜色
  • 进出聊天群提醒

功能展示

  • 登录与注册

  • 群聊

  • 群聊中与机器人聊天

  • 机器人聊天

  • 留言板

  • 更换主题

好啦~功能差不多就这些啦,这次添加了进出群提醒,主题颜色更换还有布局的一些调整。废话不多说啦,接下来该介绍介绍核心部分,以免被各位小哥哥,小姐姐打。

前端聊天代码

const infoObj = {
status: 'userstate',
nickname: this.getUserinfo.nickname,
roomId: this.roomId
}
this.socket.emit('join-room', infoObj)
this.socket.on('join-room', (joinInfo) => {
this.MsgList.push(joinInfo)
this.$nextTick(() => {
this.msgDOM.scrollTop = this.msgDOM.scrollHeight
})
})
// 聊天
this.socket.on('chat-msg', (msg) => {
console.log(msg)
this.MsgList.push(msg)
this.$nextTick(() => {
this.msgDOM.scrollTop = this.msgDOM.scrollHeight
})
})
// 离开房间
this.socket.on('leave-room', (leaveInfo) => {
this.MsgList.push(leaveInfo)
this.$nextTick(() => {
this.msgDOM.scrollTop = this.msgDOM.scrollHeight
})
})

  

后端聊天代码

io.on('connection', (socket) => {
// 进入房间
socket.on('join-room', (info) => {
// 添加到房间
socket.join(info.roomId)
const joinInfo = {
status: info.status,
text: info.nickname + '加入了群聊'
}
socket.to(info.roomId).broadcast.emit('join-room', joinInfo)
})
// 群聊天
socket.on('chat-msg', (msg) => {
saveChatMsg(msg, () => {
io.to(msg.roomId).emit('chat-msg', msg)
// 分割聊天消息,判断是否与机器人聊天
const msgArr = msg.text.split(' ')
const robotParam = {
userId: msg.userId,
roomId: msg.roomId || null,
timeStamp: msg.timeStamp + 1 || null,
text: msgArr[1]
}
if (msgArr[0] === '@小美') {
getRobotMsg(robotParam, (robotmsg) => {
saveChatMsg(robotmsg)
io.to(msg.roomId).emit('chat-msg', robotmsg)
})
}
})
})
// 机器人聊天
socket.on('robot-msg', (msg) => {
const robotParam = {
userId: msg.userId,
timeStamp: msg.timeStamp,
text: msg.text
}
getRobotMsg(robotParam, (robotmsg) => {
socket.emit('robot-msg', robotmsg)
})
})
// 离开房间
socket.on('leave-room', (info) => {
socket.leave(info.roomId)
const leaveInfo = {
status: info.status,
text: info.nickname + '离开了群聊'
}
socket.to(info.roomId).broadcast.emit('leave-room', leaveInfo)
})
})

  

vuex

export default new Vuex.Store({
state: {
// 主题颜色
themeColor: '',
// 存放用户信息
userInfo: {
userId: '',
nickname: '',
headPic: ''
},
// 机器人信息
robot: {
Info: {
userId: 'robot',
nickname: '小美',
headPic: '/static/img/robot-headpic.jpg'
},
// 机器人打招呼
greetMsg: 'hi~ 我是机器人小美,有什么可以帮您的嘛?'
}
},
getters: {
// 获取主题颜色
getThemeColor: state => {
return state.themeColor
},
// 获取登录用户信息
getUserinfo: state => {
return state.userInfo
},
// 获取机器人信息
getRobotinfo: state => {
return state.robot.Info
},
// 获取机器人欢迎语
getRobotGreetMsg: state => {
return state.robot.greetMsg
}
},
mutations: {
// 设置用户信息
setUserinfo(state, userInfo) {
state.userInfo.userId = userInfo.userId
state.userInfo.nickname = userInfo.nickname
state.userInfo.headPic = userInfo.headPic
},
// 设置聊天记录
setHistoryMsg(state, msgList) {
state.msgInfo = msgList
},
// 设置主题颜色
setThemeColor(state, color) {
state.themeColor = color
}
},
actions: {
// 注册用户
async register({commite}, data) {
const res = await url.register(data)
if (res.data.state === 0) {
return {
status: 'fail',
data: res.data.data
}
}
return {
status: 'success',
data: res.data.data
}
},
// 登录用户
async login({commite}, data) {
const res = await url.login(data)
if (res.data.state === 0) {
return {
status: 'fail',
data: res.data.data
}
}
return {
status: 'success',
data: res.data.data
}
},
// 上传图片
async upload({commite}, data) {
await url.upload(data)
},
// 获取聊天记录
async getHistoryChatMsg({commite}, data) {
const res = await url.gethistorychatmsg(data)
return {
status: 'success',
data: res.data.data.msgList
}
},
// 保存留言
async saveLeaveMsg({commite}, data) {
const res = await url.saveleavemsg(data)
return {
status: res.data.data.stateText
}
},
// 获取留言数据
async getLeaveMsg({commite}) {
const res = await url.getleavemsg()
return {
status: res.data.data.stateText,
data: res.data.data.leaveMsg
}
}
}
})

  

vue.js+socket.io+express+mongodb打造在线聊天[二]的更多相关文章

  1. vue.js+socket.io+express+mongodb打造在线聊天

    vue.js+socket.io+express+mongodb打造在线聊天 在线地址观看 http://www.chenleiming.com github地址 https://github.com ...

  2. 使用node.js + socket.io + redis实现基本的聊天室场景

    在这篇文章Redis数据库及其基本操作中介绍了Redis及redis-cli的基本操作. 其中的publish-subscribe机制应用比较广泛, 那么接下来使用nodejs来实现该机制. 本文是对 ...

  3. socket.io简单说明及在线抽奖demo

    socket.io简单说明及在线抽奖demo socket.io 简介 Socket.IO可以实现实时双向的基于事件的通信. 它适用于各种平台,浏览器或设备,也同样注重可靠性和速度. socket.i ...

  4. 使用Node.js+Socket.IO搭建WebSocket实时应用

    Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...

  5. (转)使用Node.js+Socket.IO搭建WebSocket实时应用

    Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...

  6. 使用Node.js+Socket.IO搭建WebSocket实时应用【转载】

    原文:http://www.jianshu.com/p/d9b1273a93fd Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新 ...

  7. 在线白板,基于socket.io的多人在线协作工具

    首发:个人博客,更新&纠错&回复 是昨天这篇博文留的尾巴,socket.io库的使用练习,成品地址在这里. 代码已经上传到github,传送门.可以开俩浏览器看效果. 现实意义是俩人在 ...

  8. 转载:node.js socket.io

    本文转自:http://www.xiaocai.name/post/cf1f9_7b6507  学习node.js socket.io 使用 用node.js(socket.io)实现数据实时推送 在 ...

  9. 我的学习笔记之node----node.js+socket.io实时聊天(1) (谨此纪念博客开篇)

    本想着从hello word开篇,也确实写了相关学习笔记.各种原因吧,现在又着急写出作品,便作罢. 这里将记录一个node.js+socket.io的实时聊天程序.(当然我也是跟着网上各种教程资料学习 ...

随机推荐

  1. 针对微信的一篇推送附有的数据链接进行MapReduce统计

    原推送引用:https://mp.weixin.qq.com/s/3qQqN6qzQ3a8_Au2qfZnVg 版权归原作者所有,如有侵权请及时联系本人,见谅! 原文采用Excel进行统计数据,这里采 ...

  2. Idea中开启assert断言

    先打开相应的配置面板,有以下两种方式.   然后在VM栏里输入 -enableassertions 或者 -ea 就好了 然后编写程序试试 我的目录结构如下:(因为Main class那里要写类的全限 ...

  3. Java生成图片验证码

    在日常我们在登录或者注册的时候,网页上会出现验证码让我们填写,其实利用jdk提供给我们的工具类完全可以模拟出来一个生成验证码图片的功能. package util; import javax.imag ...

  4. 笔记:Maven 插件配置 - maven-jar-plugin

    在项目中内部重用某个模块的测试代码很常见的需求,可能某个底层模块的测试代码中包含一些常用的测试工具类,或者一些高质量的测试基类供继承,这个时候Maven用户就需要通过配置此插件将测试类打包,插件配置代 ...

  5. 【Bootstrap】 一些提示信息插件

    前端总是会有很多信息提示的时候,最简单的可以用javascript自带的alert,confirm等.这些虽然和js的配合很好,但是很丑. bootstrap给我们提供了一些不同的方案比如modal的 ...

  6. 【Flask】 结合wtforms的文件上传表单

    表单中的文件上传 基本的表单渲染,表单类设置等等就不多说了,参看另一个文章即可.但是那篇文章里没有提到对于FileField,也就是上传文件的表单字段是如何处理,后端又是如何实现接受上传过来的文件的. ...

  7. 设计模式 --> (14)中介者模式

    中介者模式 用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互.中介者模式的例子很多,大到联合国安理会,小到房屋中介,都扮演了 ...

  8. 手写ButterKnife

    开发中使用注解框架可以极大地提高编码效率,注解框架用到的技术可以分为两种,运行时注解跟编译时注解.运行时注解一般配合反射机制使用,编译时注解则是用来生成模板代码.这里我们分别使用这两种方法实现Butt ...

  9. windows环境下,apache虚拟主机配置

    在windows环境下,apache从配置文件的相关配置: Windows 是市场占有率最高的 PC 操作系统, 也是很多人的开发环境. 其 VirtualHost 配置方法与 Linux 上有些差异 ...

  10. 网络1712--c语言字符数组作业总结..

    ---恢复内容开始--- 作业亮点 1.总体情况 1.大部分同学利用了流程图后,对于思路的理解有了提升. 2.很多同学在总结方面写的很不错,能够罗列问题贴出解决问题,我们能够看到你们的进步 2.作业发 ...