
最近看到一些关于websocket的东西,就决定写一个在线聊天室尝试一下。最终决定配合vue来写,采用了官方的vue脚手架vue-cli和官方的router,在本例中呢,我是用了CHAT这个对象来存储app的数据的,但后来一想,虽然项目很小,但如果用官方的vuex会更好,方便以后扩展,比如可以加上私信功能,可以在对方不在线的时候缓存发送的消息,这些都是可以的。(现在比较尴尬的就是,我把聊天室写好放到公众号号redream里,但是很少有人会同时在线,所以你会经常发现你进去的时候只有你一个人,就导致群聊不起来)
1.好吧,先来看一下我们的效果图


详细见redream文章
3.代码架构简介
- nodejs node服务器运行环境
- express 搭建node服务器
- websocket 本例核心,推送服务器消息到所有人
- socketio websocket第三方库
- vue + router 视图层双向数据绑定框架,用来简化开发、组件化开发的
- es6语法 就是好用简洁哈哈
- https 因为像websocket和很多h5的新功能,浏览器为了安全起见都仅支持https下开发
关于nodejs搭建express服务器可以看这里我就是在这里学的,代码里也借鉴了很多,关于搭建https服务器就不简介了,内容太多,推荐阿里云一年的免费证书,可以访问我的站点查看
install dependencies
npm install
serve with hot reload at localhost:8080
npm run dev
npm run build
这是在我站点上跑着的例子,大家可以看一看,在手机上效果更加,最近校招比较忙,就花了两天,没考虑兼容,欢迎大家提出意见。
这是我第一次写技术介绍文章,其实我也并没有介绍什么细节。不过感觉上面提到的每一个知识点都可以讲很多。一想写起来那么多就没耐心了,看来还是太毛躁。希望大家多多包涵,我会慢慢改进的,大家一起进步!
https://github.com/secreter/websocket_chat