用 Vue 建立一个简单的 electron 桌面应用 原 荐

栏目: JavaScript · 发布时间: 5年前

内容简介:1)一个简单的 Electron 桌面应用都是冲 Hello World! 开始的。以上是使用 electron-vue 超级迅速制作出来的 electron 桌面应用。

1. electron简介

2. 工具介绍

3. 实践效果,步骤

1)一个简单的 Electron 桌面应用都是冲 Hello World! 开始的。

用 Vue 建立一个简单的 electron 桌面应用 原 荐

以上是使用 electron-vue 超级迅速制作出来的 electron 桌面应用。

2)安装的组件

vue init simulatedgreg/electron-vue white-electron-first

用 Vue 建立一个简单的 electron 桌面应用 原 荐

3)build tool choice ?

构建 工具 的选择,比较先进的是electron-builder。

实际上调试,开发可以直接选择 electron-builder,它支持热更新,像目前大部分在使用的 vue-cli 构建出来的项目一样保存即更新。

如果是简单打包应用就直接选择 electron-packager 就好了,功能比较简单。

参考链接: https://electron.org.cn/vue/building_your_app.html

用 Vue 建立一个简单的 electron 桌面应用 原 荐

4) 下一步

> npm i  // 装包
> npm run dev  // 测试环境运行

就可以有一个初步的Electron桌面应用了。

4. 如何将网站只做成 ELectron 应用?

1)网站页面

用 Vue 建立一个简单的 electron 桌面应用 原 荐

to 桌面应用

用 Vue 建立一个简单的 electron 桌面应用 原 荐

2)熟悉 node 的朋友都知道,启动一个 node 程序,通常就是 node app.js 之类的。

把这个 Node 应用转换成一个 Electron 应用也是非常简单的,我们只不过是把 node 运行时替换成了  electron 运行时。package.json如下:

{
    "script": {
        "electron": "electron build/electron.js",
    }
}

Electron.js (一般启动项目写在main.js,具体看项目) 这个文件应该怎样写呢,这种基本都是参考成熟项目的,一般简单的如:

// electron.js"
const {app, BrowserWindow} = require('electron')
  
  // Keep a global reference of the window object, if you don't, the window will
  // be closed automatically when the JavaScript object is garbage collected.
  let win
  
  function createWindow () {
    // 创建浏览器窗口。
    win = new BrowserWindow({width: 800, height: 600})
  
    // 然后加载应用的 index.html。
    win.loadFile('index.html')
  
    // 打开开发者工具
    win.webContents.openDevTools()
  
    // 当 window 被关闭,这个事件会被触发。
    win.on('closed', () => {
      // 取消引用 window 对象,如果你的应用支持多窗口的话,
      // 通常会把多个 window 对象存放在一个数组里面,
      // 与此同时,你应该删除相应的元素。
      win = null
    })
  }
  
  // Electron 会在初始化后并准备
  // 创建浏览器窗口时,调用这个函数。
  // 部分 API 在 ready 事件触发后才能使用。
  app.on('ready', createWindow)
  
  // 当全部窗口关闭时退出。
  app.on('window-all-closed', () => {
    // 在 macOS 上,除非用户用 Cmd + Q 确定地退出,
    // 否则绝大部分应用及其菜单栏会保持激活。
    if (process.platform !== 'darwin') {
      app.quit()
    }
  })
  
  app.on('activate', () => {
    // 在macOS上,当单击dock图标并且没有其他窗口打开时,
    // 通常在应用程序中重新创建一个窗口。
    if (win === null) {
      createWindow()
    }
  })
  
  // 在这个文件中,你可以续写应用剩下主进程代码。
  // 也可以拆分成几个文件,然后用 require 导入。

上文代码中有一段 win.loadFile('index.html') 的代码,意味着你的入口页面就是 index.html, 就像我们用electron-vue 模板启动的 hello world 一样。

3)我们的 view 应用实际上就是一个 SPA 的页面,打包出来后也会有这个入口index.html 文件。

于是 npm run build 先 build 出 dist 文件后,electron.js 的 index.html 替换成 dist 目录下的 html 文件之后,出现以下问题:打包出来的 css、js 文件访问不到了。

用 Vue 建立一个简单的 electron 桌面应用 原 荐

据此文档说是可以解决的 https://blog.csdn.net/m0_37604745/article/details/79303342

应该是应用版本不同,我们项目用的 webpack 找不到以上配置,于是直接改了 index.html 里面的 css,js 引用路径。

用 Vue 建立一个简单的 electron 桌面应用 原 荐

由于我们服务加载前必须先访问登陆系统,前端项目在没有配 ha 的情况下,单独的运行个静态前端项目是不行的呢。

然而,还是做到了。

实际也比较简单:直接把这段代码改成

// 然后加载应用的 index.html。
win.loadFile('index.html')


// to 本地服务的地址就好了

win.loadUrl('http://localhost:4000')

目前这是最简单的打包一个已有应用成 electron 应该的方法。(笑)

参考资料:

https://www.qcode.in/convert-vue-js-app-native-desktop-app-using-electron/

https://electronjs.org/docs/tutorial/first-app

https://newsn.net/say/electron-vue-demo-mac-builder.html —— from 苏南大叔的《 程序如此灵动~ 》博客

https://www.jianshu.com/p/6b32763195cc

https://www.qcode.in/convert-vue-js-app-native-desktop-app-using-electron/


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Persuasive Technology

Persuasive Technology

B.J. Fogg / Morgan Kaufmann / 2002-12 / USD 39.95

Can computers change what you think and do? Can they motivate you to stop smoking, persuade you to buy insurance, or convince you to join the Army? "Yes, they can," says Dr. B.J. Fogg, directo......一起来看看 《Persuasive Technology》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

在线进制转换器
在线进制转换器

各进制数互转换器