返回目录:电脑怎么了
今天小编给各位分享网页版qq在线聊天的知识,文中也会对其通过Vue3.0桌面端聊天|vue3仿微信/QQ网页版聊天实例和微信小程序怎么制作自己的程序等多篇文章进行知识讲解,如果文章内容对您有帮助,别忘了关注本站,现在进入正文!
内容导航:
一、Vue3.0桌面端聊天|vue3仿微信/QQ网页版聊天实例
随着vue3.x越来越稳定及vite2.0的快速迭代推出,加上很多大厂相继推出了vue3的UI组件库,在2021年必然受到开发者的再一次热捧。
Vue3迭代更新频繁,目前star高达20.2K+。
// 官网地址https://v3.vuejs.org/
Vitejs目前的star达到15.7K+。
// 官网地址https://vitejs.dev/
项目介绍vue3-webchat 基于vue3.x+vuex4+vue-router4+element-plus+v3layer+v3scroll等技术架构的仿微信PC端界面聊天实例。
以上是仿制微信界面聊天效果,同样也支持QQ皮肤。
技术栈使用技术:vue3.0+vuex4+vue-router4UI组件库:element-plus(饿了么Vue3 pc端组件库)弹窗组件:V3Layer(基于Vue3自定义桌面端弹窗)滚动条组件:V3Scroll(基于Vue3自定义虚拟美化滚动条)iconfont图标:阿里字体图标库Vue3.x自定义弹窗组件大家看到的所有弹窗功能,均是自己开发的vue3.0自定义弹窗V3Layer组件。
前段时间有过一篇详细的分享,这里就不作介绍了。感兴趣的话可以去看看。
vue3.0系列:Vue3自定义PC端弹窗组件V3Layer
Vue3.x自定义美化滚动条组件为了使得项目效果一致,所有页面的滚动条均是采用vue3.0自定义组件实现。
v3scroll 一款轻量级的pc桌面端模拟滚动条组件。支持是否原生滚动条、自动隐藏、滚动条大小/层叠/颜色等功能。
大家感兴趣的话,可以去看看这篇分享。
Vue3.0系列:vue3定制美化滚动条组件v3scroll
vue.config.js项目配置/** * Vue3.0项目配置 */const path = require('path')module.exports = { // 基本路径 // publicPath: '/', // 输出文件目录 // outputDir: 'dist', // assetsDir: '', // 环境配置 devServer: { // host: 'localhost', // port: 8080, // 是否开启https https: false, // 编译完是否打开网页 open: false, // 代理配置 // proxy: { // '^/api': { // target: '<url>', // ws: true, // changeOrigin: true // }, // '^/foo': { // target: '<other_url>' // } // } }, // webpack配置 chainWebpack: config => { // 配置路径别名 config.resolve.alias .set('@', path.join(__dirname, 'src')) .set('@assets', path.join(__dirname, 'src/assets')) .set('@components', path.join(__dirname, 'src/components')) .set('@layouts', path.join(__dirname, 'src/layouts')) .set('@views', path.join(__dirname, 'src/views')) }}
Vue3引入/注册公共组件// 引入饿了么ElementPlus组件库import ElementPlus from 'element-plus'import 'element-plus/lib/theme-chalk/index.css'// 引入vue3弹窗组件v3layerimport V3Layer from '../components/v3layer'// 引入vue3滚动条组件v3scrollimport V3Scroll from '@components/v3scroll'// 引入公共组件import WinBar from '../layouts/winbar.vue'import SideBar from '../layouts/sidebar'import Middle from '../layouts/middle'import Utils from './utils'const Plugins = app => { app.use(ElementPlus) app.use(V3Layer) app.use(V3Scroll) // 注册公共组件 app.component('WinBar', WinBar) app.component('SideBar', SideBar) app.component('Middle', Middle) app.provide('utils', Utils)}export default Plugins
项目中主面板毛玻璃效果(虚化背景)
<!-- //虚化背景(毛玻璃) --><div class="vui__bgblur"> <svg xmlns="http:///pgc-image/50b2b5cefde34d6ba564ac94a4a84c86~noop.image?_iz=58558&from=article.pc_detail&x-expires=1667475794&x-signature=l0tRjdobrKRLWDONy%2FNgI1daGCA%3D" img_ img_ image_type="1" mime_type="image/png" web_uri="pgc-image/50b2b5cefde34d6ba564ac94a4a84c86">如上图:聊天编辑框部分支持文字+emoj表情、在光标处插入表情、多行文本内容。
编辑器抽离了一个公共的Editor.vue组件。
<template> <div ref="editorRef" class="editor" contentEditable="true" v-html="editorText" @click="handleClick" @input="handleInput" @focus="handleFocus" @blur="handleBlur" style="user-select:text;-webkit-user-select:text;"> </div></template>
另外还支持粘贴截图发送,通过监听paste事件,判断是否是图片类型,从而发送截图。
editorRef.value.addEventListener('paste', function(e) { let cbd = e.clipboardData let ua = window.navigator.userAgent if(!(e.clipboardData && e.clipboardData.items)) return if(cbd.items && cbd.items.length === 2 && cbd.items[0].kind === "string" && cbd.items[1].kind === "file" && cbd.types && cbd.types.length === 2 && cbd.types[0] === "text/plain" && cbd.types[1] === "Files" && ua.match(/Macintosh/i) && Number(ua.match(/Chrome\/(\d{2})/i)[1]) < 49){ return; } for(var i = 0; i < cbd.items.length; i++) { var item = cbd.items[i] // console.log(item) // console.log(item.kind) if(item.kind == 'file') { var blob = item.getAsFile() if(blob.size === 0) return // 读取图片记录 var reader = new FileReader() reader.readAsDataURL(blob) reader.onload = function() { var _img = this.result // 返回图片给父组件 emit('pasteFn', _img) } } }})
还支持拖拽图片至聊天区域进行发送。
<div class="ntMain__cont" @dragenter="handleDragEnter" @dragover="handleDragOver" @drop="handleDrop"> // ...</div>
const handleDragEnter = (e) => { e.stopPropagation() e.preventDefault()}const handleDragOver = (e) => { e.stopPropagation() e.preventDefault()}const handleDrop = (e) => { e.stopPropagation() e.preventDefault() // console.log(e.dataTransfer) handleFileList(e.dataTransfer)}// 获取拖拽文件列表const handleFileList = (filelist) => { let files = filelist.files if(files.length >= 2) { v3layer.message({icon: 'error', content: '暂时支持拖拽一张图片', shade: true, layerStyle: {background:'#ffefe6',color:'#ff3838'}}) return false } for(let i = 0; i < files.length; i++) { if(files[i].type != '') { handleFileAdd(files[i]) }else { v3layer.message({icon: 'error', content: '目前不支持文件夹拖拽功能', shade: true, layerStyle: {background:'#ffefe6',color:'#ff3838'}}) } }}
大家如果感兴趣可以自己去试试哈。
ok,基于vue3+element-plus开发仿微信/QQ聊天实战项目就分享到这里。
基于vue3.0+vant3移动端聊天实战|vue3聊天模板实例
一、微信小程序怎么制作自己的程序
一、认识微信小程序
(1)先了解应用如何开发
Web App(内嵌内浏览器打开指定网页)
Native App(原生开发,也就是使用iOS和Android代码开发)
Hybrid App(混合APP开发,写DIV+CSS+JS+PHP代码开发)
(2)微信、公众号、小程序
微信:就是一个聊天工具(类似于QQ)
微信公众号:企业或个人组织管理其粉丝/用户的应用(类似于APP)
微信小程序:不需要下载安装即可使用的软件/应用/APP
二、知识储备
【重要】HTML、CSS、JavaScript、PHP(基础)、MySQL(基础)
【次要】接触过Angular / Vue / React之类的前段框架
【次要】了解Node、ECMAScript 2015(ES6)更好
三、搭建开发环境
(1)安装开发工具
下载:
(2)傻瓜式安装
(3)创建项目:双击开发者工具,用微信扫码登录即可
(4)创建
(5)工具使用介绍
二、微信小程序怎么制作自己的程序?
一、认识微信小程序
(1)先了解应用如何开发
Web App(内嵌内浏览器打开指定网页)
Native App(原生开发,也就是使用iOS和Android代码开发)
Hybrid App(混合APP开发,写DIV+CSS+JS+PHP代码开发)
(2)微信、公众号、小程序
微信:就是一个聊天工具(类似于QQ)
微信公众号:企业或个人组织管理其粉丝/用户的应用(类似于APP)
微信小程序:不需要下载安装即可使用的软件/应用/APP
二、知识储备
【重要】HTML、CSS、JavaScript、PHP(基础)、MySQL(基础)
【次要】接触过Angular / Vue / React之类的前段框架
【次要】了解Node、ECMAScript 2015(ES6)更好
三、搭建开发环境
(1)安装开发工具
下载:
(2)傻瓜式安装
(3)创建项目:双击开发者工具,用微信扫码登录即可
(4)创建
(5)工具使用介绍
三、VUE腾讯地图web地图选点功能实现
URL:
以下接口具体参数可查看官方文档:
反向选择,需传入经纬度参数
接口调用
原文
关于网页版qq在线聊天的问题,通过《微信小程序怎么制作自己的程序?》、《VUE腾讯地图web地图选点功能实现》等文章的解答希望已经帮助到您了!如您想了解更多关于网页版qq在线聊天的相关信息,请到本站进行查找!