当前位置: 首页 > news >正文

.js项目编译成.exe程序(交叉编译全过程整理)

1.前提:

(这个文档有配套的视频解说教程,大家想看的话, 直接在 blibli搜索 , 尘埃落在星河湾 这个up主,

将vtk.js打包成.exe实录课程_哔哩哔哩_bilibili

)

先将下载库的环境搭建好:

打开编辑配置文件,下面代码依次执行

npm config edit

registry=https://registry.npmmirror.com

electron_mirror=https://cdn.npmmirror.com/binaries/electron/

electron_builder_binaries_mirror=https://npmmirror.com/mirrors/electron-builder-binaries/

npm cache clean --force

npm install --save-dev electron

2.在上面的基础上,执行下面指令: 安装打包exe需要的库.

npm install electron -D

npm install vite-plugin-electron -D 

3.创建 electron/index.ts

// app 控制应用程序的事件生命周期(相当于应用程序)

// BrowserWindow 创建并控制浏览器窗口(相当于打开桌面弹框)

import { app, BrowserWindow,dialog,Menu  } from 'electron'

import path from 'path'

 

// 定义全局变量,获取窗口实例

let win: BrowserWindow | null;

/**

 * 创建一个窗口

 */

const createWindow = () => {

  win = new BrowserWindow({

    webPreferences: {

      devTools: true,

      // 集成网页和 Node.js,也就是在渲染进程中,可以调用 Node.js 方法

      nodeIntegration: true,

      contextIsolation: false,

      //允许html页面上的javascipt代码访问nodejs 环境api代码的能力(与node集成的意思)

    }

  })

 

  const isDev = process.env.NODE_ENV === "development";

  win.setMenu(null);//移除菜单

  if (isDev) {

    win.loadURL("http://localhost:5173");

  } else {

    win.loadFile(path.join(__dirname, "../dist/index.html"))

      .catch(err => {

        dialog.showErrorBox("启动错误", `无法加载静态文件:${err}`);

      });

  }

 

}

// 初始化app(在 Electron 完成初始化时触发)

app.whenReady().then(createWindow)

 

 

4: 在 vite.config.ts中, 添加 plugins 和 css两部分 (注意,这两部分必写,否则会造成第三方三维引擎中一些交互控件的失效)

 

 

 

import { defineConfig } from 'vite'

import vue from '@vitejs/plugin-vue'

import electron from 'vite-plugin-electron'

 

export default defineConfig({

  plugins: [

    vue(),

    electron({

      entry: 'electron/index.ts',

    }),

  ],

  css: {

    preprocessorOptions: {

      scss: {

        additionalData: `$injectedColor: orange;`,

      },

    },

  },

});

 

5.打开package.json, 一些必写的内容: 红线标记的地方, 下面给出具体代码.

  "name": "digitalvtksys",

  "private": true,

  "version": "0.0.0",

  "description": "Your project description",

  "author": "HZX",

  "main": "dist-electron/index.js",

  "scripts": {

    "dev": "cross-env NODE_ENV=development vite",

    "build": "cross-env NODE_ENV=production vue-tsc --noEmit && vite build && electron-builder",

    "preview": "vite preview"

  },

  "build": {

    "appId": "com.electron.desktop",

    "productName": "electron",

    "asar": true,

    "copyright": "Copyright © 2022 electron",

    "directories": {

      "output": "release/"

    },

    "files": [

      "dist/**/*",

      "dist-electron/**/*",

      "src/assets/**/*",

      "package.json"

    ],

    "mac": {

      "artifactName": "${productName}_${version}.${ext}",

      "target": [

        "dmg"

      ]

    },

    "win": {

      "target": [

        {

          "target": "nsis",

          "arch": [

            "x64"

          ]

        }

      ],

      "artifactName": "${productName}_${version}.${ext}"

    },

    "nsis": {

      "oneClick": false,

      "perMachine": false,

      "allowToChangeInstallationDirectory": true,

      "deleteAppDataOnUninstall": false

    },

    "publish": [

      {

        "provider": "generic",

        "url": "http://127.0.0.1:8080"

      }

    ],

    "releaseInfo": {

      "releaseNotes": "版本更新的具体内容"

    }

  },

  1. 依次执行下面代码:

npm   install cross-env

npm install electron-builder -D 

//调试一下,如果成功的话,基本会启动exe程序了.

Npm run dev

Npm run build

到此,执行完成:

具体的视频教程搜索:

blibli: 尘埃落在星河湾,

相关文章:

  • 在 Ant Design Vue 中实现滚动页面时保持下拉菜单展开
  • Strawberry perl的下载,查询版本号,配置Path环境变量,查找perl解释器的位置
  • 淘宝API与小程序联动:实现“一键转卖”功能开发实战
  • 虚拟电商-话费充值业务(二)话费充值对接供应商模块开发
  • 从虚拟现实到可持续设计:唐婉歆的多维创新之旅
  • 十二、Cluster集群
  • 【计网】网络交换技术之电路交换(复习自用)
  • ACL 访问控制列表
  • 星际旅行(去年蓝桥杯省赛b组-第7题)
  • Python小练习系列 Vol.9:杨辉三角生成(数组构建 + 数学组合)
  • 基于飞腾FT2000/4的全国产标准6U VPX板卡,支持银河麒麟
  • 【计网速通】计算机网络核心知识点和高频考点——数据链路层(一)
  • flutter 专题 七十一 Flutter 自定义单选控件
  • 从ChatGPT到AutoGPT——AI Agent的范式迁移
  • 前端给后端发送数据时都需要包含哪些内容?(HTTP请求的基本组成部分)
  • Java实战:实现用户的登录注册功能
  • 【测试】每日3道面试题 3/30
  • SAP 学习笔记 - 系统移行业务 - MALSY(由Excel 移行到SAP 的收费工具)
  • 【Linux】了解基础指令(超详细)
  • 每日一题之既约分数
  • 国铁集团去年收入12830亿元增3%,全年铁路运输利润总额创新高
  • 国铁集团郑州局预计“五一”发送642.5万人
  • 浙商银行一季度净赚超59亿微增0.61%,非息净收入降逾22%
  • A股三大股指小幅低收:电力股大幅调整,两市成交10221亿元
  • 直播电商行业代表呼吁:携手并肩伸出援手助力外贸企业攻坚克难
  • 演员刘美含二手集市被曝售假,本人道歉