基于VUE多人聊天项目
项目背景
公司平台要做一个通讯系统,本来是java 来做的后面改前端+PHP来做,所以就用VUE来做这个了。
github
github地址
新人求star
技术栈
vue-axios
vuex
websocket
sass
css3
等...
已经完成进度
- 整体结构已经完成
- 好友列表完成
- 好友添加拒绝完成
- 好友列表发起聊天完成
- 聊天页面点击聊天完成
- 发送聊天完成
- 点击聊天列表清除未读消息完成
- 实时消息通知完成
- 好友动态上下线完成
- 实时加好友通知完成
- 优化发送文字长度
- 聊天记录本地储存 如果页面不刷新 则不会丢失
- 与后端已经联调完成,一期已经上线
部分代码
添加好友代码
<div class="AddContacts" id="AddContacts">
<navBar></navBar>
<div class="AddContactsBox">
<h3>添加好友</h3>
<div class="AddContactsSerchBox">
<input type="text" placeholder="请输入用户名/好友昵称..." id="serchInput" @focus="delStatus" @keydown.13="enter($event)"/>
<span @click="serchBtn">搜索</span>
<p v-if="status">{{statusMessage}}</p>
</div>
<div class="AddContactsSerchListBox">
<h4>搜索结果 <a href="javascript:;" v-if="false"> <查看推荐好友</a></h4>
<ul>
<li v-for="(list,index) in data.list" :id="list.aid" :ueraid="list.aid" v-if="(list.status != 2) && (list.aid != isselfAid)" :aa="isselfAid">
<div class="imgHd"><img :src="list.avatar"/></div>
<div class="userInfo">
<p>{{list.nickname}} <i :class="list.sex" v-if="false"></i></p>
<span :class="list.status === 0 ? 'addFriends':'addProving'" @click="addFriend(list.status,list.aid,index)"><img src="../images/addFriends.png" v-if="list.status === 0"/>{{list.status === 0 ? '好友':'待验证'}}</span>
</div>
</li>
</ul>
</div>
</div>
公共弹窗代码
<div class="RulePop" id="RulePop">
<div class="pop">
<h3>提示<span class="close" @click="$store.commit('rulestate',{type:'',status:false,data:{}})"></span></h3>
<div class="cont">
<div :class="['contMessage',type]">
<i></i>
<span>{{type === 'del' ? '确定要移除 '+ delInfo.name +' 吗?' : message[type]}}</span>
</div>
<div class="box" v-show="type === 'del'">
<a href="javascript:;" @click="delFriends()">确定</a>
<a href="javascript:;" @click="$store.commit('rulestate',{type:'',status:false,data:{}})">取消</a>
</div>
</div>
</div>
<div class="divMask"></div>
</div>
好友模块相关代码
<div class="Contacts" id="Contacts">
<div class="ContactsBox">
<div class="ChatSerch">
<input type="text" class="ChatSerchInput" placeholder="搜索..."/>
</div>
<div class="ChatList clearfix">
<div class="addContacts">
<div class="title addContactsTitle titleB" :data-num="data[1].ApplyList.length">
好友申请 [{{data[1].ApplyList.length}}]
</div>
<div class="addContactsList overflow" v-if="data[1].ApplyList.length">
<div class="ulwrapper">
<ul>
<li v-for="(list,index) in data[1].ApplyList" @click="mFadd(list.aid,list.id,true)" :useraid="list.aid" :userid="list.id">
<div class="userHd">
<div class="userHdImg"><img :src="list.avatar"/></div>
</div>
<div class="userInfo">
<div class="userInfoA">
<span class="name textHidden">{{list.nickname}}</span>
</div>
<div class="userInfoB">
<span class="oneMessage textHidden">申请加我为好友</span>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>
<div class="myFriends">
<div class="title myFriendsTitle titleB" >
我的好友 [{{data[0].onlineNum}}/{{data[0].friendsList.length}}]
</div>
<div class="myFriendsList overflow">
<div class="ulwrapper">
<ul>
<li v-for="(list,index) in data[0].friendsList" :key="index" :useraid="list.aid" :class="['',{'offline':list.is_online == 0}]" @contextmenu="showMenu(index)" :state="list.is_online" @click="mFadd(list.aid,list.id,false)">
<vue-context-menu :contextMenuData="contextMenuData" :transferIndex="transferIndex" @savedata="savedata(list.aid,list.id,false)" @newdata="newdata(list)"></vue-context-menu>
<div class="userHd">
<div class="userHdImg"><img :src="list.avatar"/></div>
<span class="onlineState online_game" v-if="false"></span>
</div>
<div class="userInfo">
<div class="userInfoA">
<span class="name textHidden">{{list.nickname}}</span>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>
</div>
</div>
<ContactsView :currentData.sync="currentData" :type.sync="type" :isDefault.sync="isDefault"></ContactsView>
</div>
聊天模块相关代码
<div class="Chat clearfix" id="Chat">
<div class="ChatBox">
<div class="ChatSerch">
<input type="text" class="ChatSerchInput" placeholder="搜索..."/>
</div>
<div class="ChatList clearfix">
<div class="ulwrapper">
<ul>
<li v-for="(list,index) in data.offlinelist" :class="[list.current === 'current' ? 'current':'']" :index="index" :current= "list.current" @click="adclick(list,index)" :useraid="list.aid" :sessionid="list.session_id" :id="list.aid">
<div :class="[list.is_online == 0 ? 'offline':'']">
<div class="userHd">
<div class="userHdImg"><img :src="list.avatar"/></div>
<span class="onlineState online_game" v-if="list.playing_status != 0">
<em><i></i>正在玩{{list.playing_game_info.name}}</em>
</span>
</div>
<div class="userInfo">
<div class="userInfoA">
<span class="name textHidden">{{list.nickname}}</span>
<span class="userMessageNum textHidden" v-if="list.message_count > 0" :num="list.message_count">{{list.message_count > 99 ? '99+': list.message_count}}</span>
</div>
<div class="userInfoB">
<span class="oneMessage textHidden">{{list.last_message}}</span>
<span class="userInfoTime textHidden">{{list.last_send_at}}</span>
</div>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>
<ChatView :chatData.sync="chatData" :isDefault.sync="isDefault" :sendMsg.sync="sendMsg"></ChatView>
</div>`
项目截图
基于VUE多人聊天项目的更多相关文章
- 基于@vue/cli 的构建项目(3.0)
1.检测node的版本号 注意:1.Vue CLI需要Node.js的版本 8.9+(推荐8.11.0+) 所以在安装Vue CLI之前先看下node的版本 node -v 2.安装@vue/cli ...
- 基于Vue 和 webpack的项目实现
Vue.js 是一款极简的 mvvm 框架,如果让我用一个词来形容它,就是 “轻·巧” .如果用一句话来描述它,它能够集众多优秀逐流的前端框架之大成,但同时保持简单易用.废话不多说,来看几个例子: & ...
- 基于vue现有项目的服务器端渲染SSR改造
前面的话 不论是官网教程,还是官方DEMO,都是从0开始的服务端渲染配置.对于现有项目的服务器端渲染SSR改造,特别是基于vue cli生成的项目,没有特别提及.本文就小火柴的前端小站这个前台项目进行 ...
- [译]基于Vue.js的10个最佳UI框架,用于构建移动应用程序
原文查看10 Best Vue.js based UI Frameworks for Building Mobile Apps 如果您期待使用Vue.js构建移动应用程序,那么您可以选择许多可用的UI ...
- 与众不同 windows phone (30) - Communication(通信)之基于 Socket TCP 开发一个多人聊天室
原文:与众不同 windows phone (30) - Communication(通信)之基于 Socket TCP 开发一个多人聊天室 [索引页][源码下载] 与众不同 windows phon ...
- 基于Vue.js的大型报告页项目实现过程及问题总结(一)
今年5月份的时候做了一个测评报告项目,需要在网页正常显示的同时且可打印为pdf,当时的技术方案采用jquery+template的方式,因为是固定模板所以并没有考虑报告的模块化区分,九月底产品提出新的 ...
- 基于Vue.js 2.0 + Vuex打造微信项目
一.项目简介 基于Vue + Vuex + Vue-router + Webpack 2.0打造微信界面,实现了微信聊天.搜索.点赞.通讯录(快速导航).个人中心.模拟对话.朋友圈.设置等功能. 二. ...
- 基于VUE开发项目
前言 最近由于公司需要,需要写一个相对来说比较大型的后台管理系统.为了保证管理系统操作体验较为舒适并且项目后期益于维护,最后决定基于VUE全家桶来开发一个高度组件化的单页SPA应用. 技术选型 vue ...
- 基于 Vue.js 之 iView UI 框架非工程化实践记要 使用 Newtonsoft.Json 操作 JSON 字符串 基于.net core实现项目自动编译、并生成nuget包 webpack + vue 在dev和production模式下的小小区别 这样入门asp.net core 之 静态文件 这样入门asp.net core,如何
基于 Vue.js 之 iView UI 框架非工程化实践记要 像我们平日里做惯了 Java 或者 .NET 这种后端程序员,对于前端的认识还常常停留在 jQuery 时代,包括其插件在需要时就引 ...
随机推荐
- Python 使用PyQt5进行开发(一)
Qt 是一个1991年由Qt Company开发的跨平台C++图形用户界面应用程序开发框架.它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台工具和服务器. 我们先简单使用Qt进行一个小工 ...
- 在aspx页面的checkbox取值验证
在做项目的时候遇到了一个选择性的问题,之前都可以用$("#id").checked,但是不知道为什么现在不可以了,只能if($(this).is(":checked&qu ...
- Windows程序调用dll
可以写在WndProc的WM_CREATE里面,不能写在WinMain里面
- PHP面向对象-设计模式 单例模式 简单工厂模式 工厂方法模式
1.单例模式 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例.即一个类只有一个对象实例. 要实现每一个类只有一个实例,就需 ...
- promise不会被return触发, 一个promise对象中不会被Promise.reject触发
1. let a = new Promise((resolve,reject)=>{ return 23 }) a; // promise <pending> 2. let a = ...
- 阶段3 1.Mybatis_10.JNDI扩展知识_3 补充-测试JNDI数据源的使用以及使用细节
在webapp文件夹下新建目录META-INF 把context.xml文件复制过去. 拿资料里面的SqlMapConfig.xml文件 全部复制到项目的SqlMapConfig.xml里面来. ja ...
- .net core 学习小结之 PostMan报415
首先415的官方解释是:对于当前请求的方法和所请求的资源,请求中提交的实体并不是服务器中所支持的格式,因此请求被拒绝. 也就是说我所准备的数据格式并不是后台代码使用的数据格式 后台代码如下 using ...
- vue引入query
1 首先先安装query.(cnpm install query --save-dev)或者 在package.json里的dependencies加入"jquery" : &qu ...
- python 三元表达式
python 三元表达式(ternary expression) 把 if-else块 写到一行或者一个表达式中 并且产生一个值 value = true if condition else fal ...
- 客户端通过url向后端传递参数
在前端我们不仅可以通过get请求携带参数的方式向服务端传数据: https://127.0.0.1/index/?id=1&name=alex Django也允许通过,path路径的方式向se ...