手把手教你vue3.0及以上版本+electron最新版框架+addons调用

node 当前版本 v12.2.0 ,v14.0.0及以上提示version不一致的问题,所以只能降级
electron v8.2.3 目前是最高的版本,亲试有用
1.安装vue3.0以上版本,目前最新版本v4.3.1

  npm i @vue/cli -g

在终端输入

  vue create vue-test

按照提示直到安装完成
2.进入vue-test目录下

      npm install electron@8.2.3 --save-dev 

这步安装比较慢,目前cnpm淘宝源上还没有最新版,所以耐心等待
3.新建vue.config.js,贴入如下代码块

    module.exports = {
      // indexPath:'./', // vue3.0以上已经废弃 
      publicPath:'./' ,// 启动是页面出现空白,修改此配置,原先默认'/'修改为'./'
      outputDir:'public/dist',
      chainWebpack: config => {   //修改webpack打包的入口文件。需要在根目录建两个对应入口js文件
            config.entry('app').clear().add('./src/renderer/main.js')
    }
    };

4.新建主程序文件main.js ,目录如下./public/main.js

const {app, BrowserWindow} =require('electron');//引入electron
const loadUrl = process.env.NODE_ENV === 'development' ? `http://localhost:8080` : `file://${__dirname}/dist/index.html`
let win;
let windowConfig = {
  width:800,
  height:600
};//窗口配置程序运行窗口的大小
function createWindow(){
    win = new BrowserWindow(windowConfig);//创建一个窗口
    win.loadURL(loadUrl );//在窗口内要展示的内容index.html 就是打包生成的index.html
    win.webContents.openDevTools();  //开启调试工具
    win.on('close',() => {
      //回收BrowserWindow对象
    win = null;
  });
  win.on('resize',() => {
     win.reload();
     })
  }
 app.on('ready',createWindow);
 app.on('window-all-closed',() => {
 app.quit();
 });
  app.on('activate',() => {
  if(win == null){
    createWindow();
 }
});

5.新建package.json

{
   "name": "vue-test.",
   "version": "0.1.0",
   "main": "public/main.js",
   "private": true,
   "scripts": {
     "start": "cross-env NODE_ENV=development nodemon --watch public/main.js --exec electron .",
     "pack": "electron-builder --dir",
     "win32": "npm run build && electron-builder --win --ia32",
     "serve": "vue-cli-service serve",
     "dev": "npm run build && npm run start",
     "build": "cross-env NODE_ENV=production vue-cli-service build",
     "lint": "vue-cli-service lint"
 },
   "build": {
"productName": "vue-test.exe",
"appId": "vue-test",
"copyright": "xxxx",
"directories": {
  "output": "build"
},
"nsis": {
  "oneClick": false,
  "allowElevation": true,
  "allowToChangeInstallationDirectory": true
},
"publish": [
  {
    "provider": "generic",
    "url": "http://160.9.225.11:3000/"
  }
],
"files": [
  "dist/**/*",
  "./public/main.js"
],
"dmg": {
  "contents": [
    {
      "x": 410,
      "y": 150,
      "type": "link",
      "path": "/Applications"
    },
    {
      "x": 130,
      "y": 150,
      "type": "file"
    }
  ]
},
"mac": {
  "icon": "build/icons/icon.icns"
},
"win": {
  "icon": "build/icons/aims.ico",
  "target": [
    {
      "target": "nsis",
      "arch": [
        "ia32"
      ]
    }
  ]
},
"linux": {
  "icon": "build/icons"
  }
 },
  "dependencies": {
    "core-js": "^3.6.4",
    "electron-asar-hot-updater": "^0.1.3",
    "nan": "^2.14.1",
    "node-fetch": "^2.6.0",
     "vue": "^2.6.11"
    },
 "devDependencies": {
   "@vue/cli-plugin-babel": "~4.3.0",
   "@vue/cli-plugin-eslint": "~4.3.0",
   "@vue/cli-service": "~4.3.0",
   "babel-eslint": "^10.1.0",
   "cross-env": "^7.0.2",
   "electron": "^8.2.3",
   "electron-builder": "^22.5.1",
   "electron-log": "^4.1.1",
   "electron-rebuild": "^1.10.1",
   "eslint": "^6.7.2",
   "eslint-plugin-vue": "^6.2.2",
   "iconv-lite": "^0.5.1",
   "nodemon": "^2.0.2",
   "vue-template-compiler": "^2.6.11"
},
 "eslintConfig": {
"root": true,
"env": {
  "node": true
},
"extends": [
  "plugin:vue/essential",
  "eslint:recommended"
],
"parserOptions": {
  "parser": "babel-eslint"
},
"rules": {}
 },
  "browserslist": [
    "> 1%",
  "last 2 versions",
"not dead"
 ]
}

6.根目录输入npm run start,出现如下界面
QQ图片20200506221715.png

7.安装electron-builder

    npm install electron-builder --save-dev

输入打包命令:

    npm run win32

出现如下错误

   DONE  Build complete. The dist directory is ready to be deployed.
         INFO  Check out deployment instructions at https://cli.vuejs.org/guide/deployment.html

   (node:18068) ExperimentalWarning: The fs.promises API is experimental
   • electron-builder  version=22.5.1 os=10.0.17763
   • loaded configuration  file=package.json ("build" field)
   • description is missed in the package.json  appPackageFile=D:\infoharbor\package.json
  • author is missed in the package.json  appPackageFile=D:\infoharbor\package.json
  • writing effective config  file=build\builder-effective-config.yaml
 • packaging       platform=win32 arch=ia32 electron=8.2.3 appOutDir=build\win-ia32-unpacked
 ⨯ Application entry file "public\main.js" in the "D:\infoharbor\build\win-ia32- 
 unpacked\resources\app.asar" does not exist. Seems like a wrong configuration.  stackTrace=
                                                                                                                                                               
 Error: Application entry file "public\main.js" in the "D:\infoharbor\build\win-ia32- 
 unpacked\resources\app.asar" does not exist. Seems like a wrong configuration.
                                                                                                                                                                   
 at error (D:\infoharbor\node_modules\app-builder-lib\src\asar\asarFileChecker.ts:7:12)
                                                                                                                                                                   
 at checkFileInArchive (D:\infoharbor\node_modules\app-builder- 
 lib\src\asar\asarFileChecker.ts:33:11)
 npm ERR! code ELIFECYCLE
 npm ERR! errno 1
 npm ERR! infoharbor@0.1.0 win32: `npm run build && electron-builder --win --ia32`
 npm ERR! Exit status 1
 npm ERR!
 npm ERR! Failed at the infoharbor@0.1.0 win32 script.
 npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

 npm ERR! A complete log of this run can be found in:
 npm ERR!     C:\Users\binbin.song\AppData\Roaming\npm-cache\_logs\2020-04-24T12_47_47_479Z-debug.log

原因是打包的.asr文件中找不到主程序的入口文件public/main.js
解决方法,在项目更目录新建public文件夹,把electron的主进程文件main.js 移到public文件夹下,
和第三步中outputDir:'public/dist',要一起配置才能生效
到此,重新打包即可成功。
nodejs addons的的例子见https://www.jianshu.com/p/ce89f8407e8b

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352