IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 01_Eletron集成Vue -> 正文阅读

[JavaScript知识库]01_Eletron集成Vue

[Electron] 记一次 Vue 集成 Electron

  • 具体步骤在转载链接中不加以赘述,在这描述一下楼主遇到的问题及解决方案

  • 大致方法为安装创建Vue项目,并在项目中引入Electron
    主要配置文件为:
    新增文件夹目录如下:
    请添加图片描述
    main.js:

    const { app, BrowserWindow } = require("electron");
    
    function createWindow() {
      // 创建浏览器窗口
      const win = new BrowserWindow({
        width: 800,
        height: 600,
        webPreferences: {
          nodeIntegration: true,
        },
      });
    
      // 修改为加载 Vue 服务地址
      win.loadURL("http://localhost:8080/");
    
      // 打开开发者工具
      win.webContents.openDevTools();
    }
    
    // Electron会在初始化完成并且准备好创建浏览器窗口时调用这个方法
    // 部分 API 在 ready 事件触发后才能使用。
    app.whenReady().then(createWindow);
    
    //当所有窗口都被关闭后退出
    app.on("window-all-closed", () => {
      // 在 macOS 上,除非用户用 Cmd + Q 确定地退出,
      // 否则绝大部分应用及其菜单栏会保持激活。
      if (process.platform !== "darwin") {
        app.quit();
      }
    });
    
    app.on("activate", () => {
      // 在macOS上,当单击dock图标并且没有其他窗口打开时,
      // 通常在应用程序中重新创建一个窗口。
      if (BrowserWindow.getAllWindows().length === 0) {
        createWindow();
      }
    });
    
    // 您可以把应用程序其他的流程写在在此文件中
    // 代码 也可以拆分成几个文件,然后用 require 导入。
    

    electron-run-dev.js:

    const { exec } = require("child_process");
    
    // 定义进程
    // vue 服务进程
    let dev_vue_process = null;
    // electron 服务进程
    let dev_electron_process = null;
    
    init();
    // 启动服务
    function init() {
      // 启动Vue服务
      if (dev_vue_process == null) {
        // 执行启动 Vue 服务命令
        dev_vue_process = exec("vue-cli-service serve", {});
    
        dev_vue_process.stdout.on("data", (data) => {
          electronLog(data);
          // 当 Vue 执行输出 http 访问连接时判断启动成功
          if (data.indexOf("http") > -1) {
            // 启动 electron
            startElectron();
          }
        });
        dev_vue_process.stderr.on("data", (data) => {
          if (data.indexOf("<s> [webpack.Progress]") < 0) {
            electronLog(data);
          }
        });
      }
    }
    
    // 启动 electron
    function startElectron() {
      if (dev_electron_process == null) {
        // 执行 electron 入口为 package.json 中配置的 main 属性
        dev_electron_process = exec("electron .", {});
        dev_electron_process.stdout.on("data", (data) => {
          console.log(data);
        });
        dev_electron_process.stderr.on("data", (data) => {
          console.log(data);
        });
        dev_electron_process.on("close", () => {
          // 进程关闭时退出
          process.exit();
        });
      }
    }
    
    // 打印日志
    function electronLog(data) {
      let log = "";
      data = data.toString().split(/\r?\n/);
      data.forEach((line) => {
        log += `  ${line}\n`;
      });
      if (/[0-9A-z]+/.test(log)) {
        console.log(
          "┏ Electron -------------------" +
            "\n\n" +
            log +
            "┗ ----------------------------" +
            "\n"
        );
      }
    }
    
    
  • 需要在package.json中修改配置信息

  • 运行 npm run electron-dev即可成功运行项目
    请添加图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-31 16:32:00  更:2021-07-31 16:32:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/6 21:33:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码