博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
electron+vue框架搭建桌面应用
阅读量:535 次
发布时间:2019-03-08

本文共 2141 字,大约阅读时间需要 7 分钟。

electron+vue相关文档:

electron+vue官方文档:

一、electron+vue是什么

electron+vue 是一个结合 vue-cli 与 electron 的项目,主要避免了使用 vue 手动建立起 electron 应用程序,该程序包含了 vue-loader 的 webpack、electron-packager 或是 electron-builder,以及一些最常用的插件,如vue-router、vuex 等等的脚手架。

二、electron+vue搭建

在构建之前,请确保自己环境是否已配置好,若没有配置,请自行配置相关环境。

可以使用yarn安装或npm安装electron+vue。yarn安装会比npm快。

若没安装yarn,请安装yarn(yarn):

window小伙伴在安装electron+vue时会报错,所以,在安装之前,请先安装相关windows-build-tools。

这里注意安装windows-build-tools时,一定要以管理身份打开cmd命令提示符,然后输入以下yarn global add windows-build-tools或npm install --global windows-build-tools

这样才能安装成功。若不以管理身份打开cmd命令提示符安装会出现如下图错误:

image.png

1.windows-build-tools可以使用以下两种npm或yarn方式安装

npm的安装命令

npm install --global windows-build-tools

yarn安装命令

yarn global add windows-build-tools
yarn安装结果如下:
image.png

2.建立一个名为my-project的electron+vue项目

npm install -g vue-cli
vue init simulatedgreg/electron-vue my-project

image.png

3.安装依赖并运行你的程序

进入改文件目录
cd my-project
安装相关依赖
yarn # 或者 npm install
运行项目
yarn run dev # 或者 npm run dev

image.png

输入yarn run dev运行

image.png

4.界面图:

image.png

代码文件目录官网介绍:

image.png

将项目打包,这个打包过程可能需要安装其他东西,所以等待时间会很长,我就打包了差不多近1小时

yarn run dev

image.png

electron-vue报错Webpack ReferenceError:process is not defined

在使用electron-vue时,运行npm run dev出现如下错误

在这里插入图片描述

解决方式:

找到.electron-vue/webpack.web.config.js 和.electron-vue/webpack.renderer.config.js中的HtmlWebpackPlugin,添加templateParameters,修改后如下:

plugins: [    new VueLoaderPlugin(),    new MiniCssExtractPlugin({filename: 'styles.css'}),    new HtmlWebpackPlugin({      filename: 'index.html',      template: path.resolve(__dirname, '../src/index.ejs'),	  templateParameters(compilation, assets, options) {        return {          compilation: compilation,          webpack: compilation.getStats().toJson(),          webpackConfig: compilation.options,          htmlWebpackPlugin: {            files: assets,            options: options          },          process,        };      },      minify: {        collapseWhitespace: true,        removeAttributeQuotes: true,        removeComments: true      },      nodeModules: process.env.NODE_ENV !== 'production'        ? path.resolve(__dirname, '../node_modules')        : false    }),    new webpack.HotModuleReplacementPlugin(),    new webpack.NoEmitOnErrorsPlugin()  ],

参考:

转载地址:http://xwviz.baihongyu.com/

你可能感兴趣的文章