当前位置:首页 > 技术分析 > 正文内容

Electron+Vue3 跨平台仿QQ/TIM聊天应用实例

ruisui883个月前 (02-03)技术分析10

前段时间有给大家分享两个vue3.0实战项目,vue3仿微信pc版 | vue3仿抖音小视频。今天再给大家分享一个最新开发的vue3+electron跨端仿制QQ聊天应用。

项目简介

electron-qchat 基于vue3.0+electron11+antdv+v3layer+v3scroll等技术开发的跨平台模仿QQ桌面端聊天软件。

使用技术

  • 编码+技术:VScode | Vue3.0+Electron11.2.3+Vuex4+VueRouter@4
  • UI组件库:Ant-design-vue^2.0.0 (蚂蚁金服桌面端vue3组件库)
  • 打包器:vue-cli-plugin-electron-builder
  • 按需引入:babel-plugin-import^1.13.3
  • 弹窗组件:V3layer(基于vue3自定义dialog组件)
  • 滚动条组件:V3scroll(基于vue3自定义虚拟滚动条)

项目目录结构

vue3+electron实现多窗口模式

项目中的弹窗分为vue3自定义弹窗和electron构建多窗体弹窗。

vue3.0系列:Vue3自定义PC端弹窗组件V3Layer

至于使用electron如何快速搭建项目及构建多窗体模式,大家可以去看看之前的这篇分享。

基于 vue3+electron 创建多窗口踩坑记

Vue3+Electron实现QQ导航菜单/新开窗口

Electron自定义拖拽|最大/小/关闭按钮

项目整体采用无边框 frame: false 模式,所以需要自定义顶部导航栏。之前也有个一篇分享,感兴趣的可以去看下。

vue3+electron11自定义最小/大化/关闭按钮

vue3+electron项目/打包配置

创建项目的时候,根目录有一个vue.config.js配置文件。里面可以配置一些electron-builder打包参数。

/**
 * 项目配置文件
 */

const path = require('path')

module.exports = {
    // 基本路径
    // publicPath: '/',

    // 输出文件目录
    // outputDir: 'dist',

    // assetsDir: '',

    // 环境配置
    devServer: {
        // host: 'localhost',
        // port: 8080,
        // 是否开启https
        https: false,
        // 编译完是否打开网页
        open: false,
        
        // 代理配置
        // proxy: {
        //     '^/api': {
        //         target: '',
        //         ws: true,
        //         changeOrigin: true
        //     },
        //     '^/foo': {
        //         target: ''
        //     }
        // }
    },

    // 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('@module', path.join(__dirname, 'src/module'))
            .set('@plugins', path.join(__dirname, 'src/plugins'))
            .set('@layouts', path.join(__dirname, 'src/layouts'))
            .set('@views', path.join(__dirname, 'src/views'))
    },

    // 插件配置
    pluginOptions: {
        electronBuilder: {
            // 配置后可以在渲染进程使用ipcRenderer
            nodeIntegration: true,

            // 项目打包参数配置
            builderOptions: {
                "productName": "electron-qchat", //项目名称 打包生成exe的前缀名
                "appId": "com.example.electronqchat", //包名
                "compression": "maximum", //store|normal|maximum 打包压缩情况(store速度较快)
                "artifactName": "${productName}-${version}-${platform}-${arch}.${ext}", //打包后安装包名称
                // "directories": {
                //     "output": "build", //输出文件夹(默认dist_electron)
                // },
                "asar": false, //asar打包
                // 拷贝静态资源目录到指定位置
                "extraResources": [
                    {
                        "from": "./static",
                        "to": "static"
                    },
                ],
                "nsis": {
                    "oneClick": false, //一键安装
                    "allowToChangeInstallationDirectory": true, //允许修改安装目录
                    "perMachine": true, //是否开启安装时权限设置(此电脑或当前用户)
                    "artifactName": "${productName}-${version}-${platform}-${arch}-setup.${ext}", //打包后安装包名称
                    "deleteAppDataOnUninstall": true, //卸载时删除数据
                    "createDesktopShortcut": true, //创建桌面图标
                    "createStartMenuShortcut": true, //创建开始菜单图标
                    "shortcutName": "ElectronQChat", //桌面快捷键图标名称
                },
                "win": {
                    "icon": "./static/shortcut.ico", //图标路径
                }
            }
        }
    }
}

electron实现截图功能

聊天应用一般都需要有截图功能,这里使用了Node调用截图dll来实现。

// 屏幕截图
ipcMain.on('win-capture', () => {
    console.log('调用微信dll截图...')
    let printScr = execFile(path.join(__dirname, '../static/screenShot/PrintScr.exe'))
    printScr.on('exit', (code) => {
        if(code) {
            console.log(code)
        }
    })
})

如果出现打包后截图无效,则需要配置 extraResources 参数。

另外记得创建项目前最好不要设置中文目录,否则打包会出错。

ok,以上就是vue3+electron11开发跨端仿QQ客户端实例。希望大家能喜欢~~

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1500.html

标签: vue 多页面
分享给朋友:

“Electron+Vue3 跨平台仿QQ/TIM聊天应用实例” 的相关文章

如何在GitLab上回退指定版本的代码?GitLab回退指定版本问题分析

在Git中,回退到指定版本并不是删除或撤销之前的提交,而是创建一个新的提交,该提交包含指定版本的内容。这意味着您需要将当前代码更改与指定版本之间的差异进行比较,并将其合并到一个新的提交中。如果您没有更新本地代码,并且您希望将 GitLab 仓库回退到指定版本,您可以使用以下命令:git fetchg...

快速掌握 Git:程序员必会的版本控制技巧

在现代软件开发中,版本控制系统(VCS)是开发人员不可或缺的工具。无论是个人项目,还是多人协作的团队开发,良好的版本控制都能确保代码管理的高效性与稳定性。而在版本控制系统中,Git 凭借其分布式、灵活性和高效性,成为了最流行的工具之一。几乎所有的开发团队都在使用 Git 来管理代码版本、协作开发和追...

BuildKit 镜像构建工具

#暑期创作大赛#快速开始 对于 Kubernetes 部署,请参阅examples/kubernetes。BuildKit 由buildkitd守护进程和buildctl客户端组成。虽然buildctl客户端可用于 Linux、macOS 和 Windows,但buildkitd守护程序目前仅适用于...

USB电池充电基础:应急指南

USB为便携设备供电与其串行通信功能一样,已经成为一种标准应用。如今,USB 供电已经扩展到电池充电、交流适配器及其它供电形式的应用。应用的普及带来的一个显著效果是便携设备的充电和供电可以互换插头和适配器。因此,相对于过去每种装置都采用专用适配器的架构相比,目前的解决方案允许采用多种电源进行充电。毋...

Vue进阶(二十六):详解router.push()

在Vue2.0路由跳转中,除了使用 <router-link> 声明式创建 a 标签来定义导航链接,还可以借助 router 的实例方法,通过编码式编写代码来实现。router.push(location)想要导航到不同的 URL,则使用 router.push 方法。这个方法会向 hi...

vue父组件修改子组件的值(通过调用子组件的方法)

props只支持第一次加载这个组件的时候获取父组件的值,后续修改父组件的值得时候子组件并不会动态的更改。然而我们想要通过父组件修改子组件的值要怎么做呢?可以通过ref的方式调用子组件的方法改变子组件的值。子组件<template><div><span>{{data...