Electron + Vue3 开发桌面应用+附源码

news2024/11/14 11:54:35

什么是 Electron?

Electron 是一个使用 JavaScript、HTML 和 CSS 构建跨平台桌面应用程序的框架。它由 GitHub 开发并维护,允许开发者使用现代 Web 技术创建原生应用程序。Electron 结合了 Chromium 渲染引擎和 Node.js 运行时环境,使得开发者可以在同一个项目中同时利用前端和后端的技术栈。

Electron 主要特点

  1. 跨平台:
  • 一次编写,可在 Windows、macOS 和 Linux 上运行。
  1. Web 技术栈:
  • 使用 HTML、CSS 和 JavaScript 进行开发,降低学习成本。
  1. Node.js 集成:
  • 访问操作系统级别的功能,如文件系统操作和网络请求
  1. 丰富的生态系统:
  • 大量社区支持和第三方库,便于快速集成功能。
  1. 高性能:
  • 通过优化和底层技术支持,实现高性能应用。

基本架构

  1. 主进程:
  • 管理应用生命周期、创建和管理窗口、处理与操作系统的交互。
  • 使用 Node.js 编写,运行在 Node.js 环境中。
  1. 渲染进程:
  • 显示用户界面,每个窗口有一个独立的渲染进程。
  • 使用 Chromium 渲染引擎,运行 Web 页面和应用。
  • 可访问 Node.js API,但默认开启上下文隔离以提高安全性和性能。

1. 第一步创建一个electron + VUE3项目

复制下面代码输入到PowerShell , 因为我们用不到路由ts等 , 创建项目得时候一路回车点击否就好了,想要用得可自行配置

```# 项目名称,默认为 electron+vue3  名称自取
# 项目名称,默认为 electron+vue3
$project_name = "electron+vue3"

# 切换到淘宝镜像
npm config set registry https://registry.npm.taobao.org

# 设置 Electron 镜像
$env:ELECTRON_MIRROR="https://npmmirror.com/mirrors/electron/"

# 安装 create-vue
npm install -g create-vue

# 初始化 Vue 项目
create-vue $project_name

# 进入项目目录
Set-Location $project_name

# 安装依赖
npm install

# 安装 Electron
npm install electron --save-dev

# 启动开发服务器
npm run dev


在根目录创建 electron 文件夹,新建 index.html 文件,添加如下代码: 在 electron 目录下新建文件 main.js命令创建 --命令创建

  1. 导航到electron+vue3项目根目录,运行PowerSholl运行下列代码(创建 electron 文件夹建立index.thml文件并初始化html文件)

项目根目录下PowerShell输入

mkdir electron ; cd electron ; `
$htmlContent = @'
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Electron App</title>
</head>
<body>
  <h1>Hello, Electron!</h1>
</body>
</html>
'@ ; `
Set-Content -Path index.html -Value $htmlContent -Encoding utf8


  1. 继续执行以下命令,创建 main.js 文件并添加内容
# 定义 main.js 内容并写入文件
$jsContent = @'
// 引入 Electron 的 app 和 BrowserWindow 模块
const { app, BrowserWindow } = require('electron');
// 引入 Node.js 的 path 模块,用于处理文件路径
const path = require("path");

// 创建主窗口的函数
const createWindow = () => {
  // 创建一个新的浏览器窗口
  const mainWindow = new BrowserWindow({
    width: 800,  // 设置窗口宽度为 800 像素
    height: 600, // 设置窗口高度为 600 像素
  });

  // 使用 loadFile 方法加载 electron/index.html 文件
  // path.join(__dirname, "./index.html") 用于构建文件的绝对路径
  mainWindow.loadFile(path.join(__dirname, "./index.html"));
};

// 当 Electron 应用准备就绪时,调用 createWindow 函数
app.whenReady().then(() => {
  createWindow();
});

// 当所有窗口关闭时,退出应用(除了 macOS)
app.on("window-all-closed", () => {
  if (process.platform !== "darwin") { // 如果不是 macOS 系统
    app.quit(); // 退出应用
  }
});

// 当应用被激活时,创建一个新的窗口(主要用于 macOS)
app.on("activate", () => {
  if (BrowserWindow.getAllWindows().length === 0) { // 如果当前没有打开的窗口
    createWindow(); // 创建新的窗口
  }
});
'@ ; `
Set-Content -Path main.js -Value $jsContent -Encoding utf8

3. 创建完成后文件位置示例图,可以手动创建

在这里插入图片描述

indin.html 完整代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Electron App</title>
</head>
<body>
  <h1>Hello, Electron!</h1>
</body>
</html>

main.js 完整代码

// 引入 Electron 的 app 和 BrowserWindow 模块
const { app, BrowserWindow } = require('electron');
// 引入 Node.js 的 path 模块,用于处理文件路径
const path = require("path");

// 创建主窗口的函数
const createWindow = () => {
  // 创建一个新的浏览器窗口
  const mainWindow = new BrowserWindow({
    width: 800,  // 设置窗口宽度为 800 像素
    height: 600, // 设置窗口高度为 600 像素
  });

  // 使用 loadFile 方法加载 electron/index.html 文件
  // path.join(__dirname, "./index.html") 用于构建文件的绝对路径
  mainWindow.loadFile(path.join(__dirname, "./index.html"));
};

// 当 Electron 应用准备就绪时,调用 createWindow 函数
app.whenReady().then(() => {
  createWindow();
});

// 当所有窗口关闭时,退出应用(除了 macOS)
app.on("window-all-closed", () => {
  if (process.platform !== "darwin") { // 如果不是 macOS 系统
    app.quit(); // 退出应用
  }
});

// 当应用被激活时,创建一个新的窗口(主要用于 macOS)
app.on("activate", () => {
  if (BrowserWindow.getAllWindows().length === 0) { // 如果当前没有打开的窗口
    createWindow(); // 创建新的窗口
  }
});

4. 编辑 package.json 文件

项目根目录下PowerShell输入

# 备份 package.json 文件
Copy-Item -Path package.json -Destination package.json.bak

# 新的内容
$newContent = @'
{
  "name": "my-electron-app",
  "version": "1.0.0",
  "main": "electron/main.js",
  "scripts": {
    "electron:dev": "electron ."
  }
}
'@

# 写入新的内容到 package.json 文件
Set-Content -Path package.json -Value $newContent

# 查看修改后的 package.json 文件内容
Get-Content -Path package.json

添加有延迟,可自行添加
“main”: “electron/main.js” 跟 “electron:dev”: “electron .”
package.json完整示例:

{
  "name": "electron-vue3",
  "version": "0.0.0",
  "private": true,
  "type": "module",
  "main": "electron/main.js",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview",
    "electron:dev": "electron ."
  },
  "dependencies": {
    "vue": "^3.5.12"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^5.1.4",
    "electron": "^33.0.2",
    "vite": "^5.4.10"
  }
}

5. 运行Electron

 npm run electron:dev 

运行成功示例图:

在这里插入图片描述

6. Electron + Vue3结合

  • 编辑 package.json 文件,确定本地运行端口
  • port: 3000
export default defineConfig({
  server: {
    port: 3000
  },
  plugins: [
    vue(),
  ],

  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url))
    }
  }
})
  • 编辑 electron/main.js 文件,修改运行为本地
  • win.loadURL(‘http://localhost:3000’);
import { app, BrowserWindow } from 'electron';
import path from 'path';
import { fileURLToPath } from 'url';

// 获取当前文件的目录路径
const __dirname = path.dirname(fileURLToPath(import.meta.url));

let win;  // 使用 let 声明 win 变量

function createWindow() {
  win = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation: false,
    },
  });

  // 生成文件路径
  const indexPath = path.join(__dirname, '../dist/index.html');
  console.log('Loading URL:', `file://${indexPath}`);

  // 加载 Vue 开发服务器的地址
  //也可以替换为你项目得域名IP
  // win.loadURL('http://localhost:3000');
  win.loadURL(`file://${indexPath}`);

  // 监听窗口关闭事件
  win.on('closed', () => {
    win = null;  // 清除引用
  });
}

app.whenReady().then(() => {
  createWindow();

  app.on('activate', () => {
    if (BrowserWindow.getAllWindows().length === 0) {
      createWindow();
    }
  });
});

app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();
  }
});

5. 再次Electron

 npm run electron:dev 

运行效果示例图:

在这里插入图片描述

4. 打包应用

  • 安装 electron-builder
npm install electron-builder --save-dev
或者
yarn add electron-builder --dev
  • 修改 Vite 配置
  • 在 vite.config.js 中,将 base 选项设置为 “./”,以确保打包后的资源路径正确。
export default defineConfig({
  base: './',
  plugins: [vue()],
  // 其他配置项
});
  • 修改 Electron 主进程配置
  • 在 electron/main.js 文件中,修改 mainWindow.loadURL 的参数为 Vue 打包后的文件路径。
 // 加载 Vue 打包后的文件路径
  mainWindow.loadURL(`file://${path.join(__dirname, '../dist/index.html')}`);

  • 在 package.json 中添加打包 Electron 的脚本electron:build;
"main": "electron/main.js",
"scripts": {
  "dev": "vite",
  "build": "vite build",
  "preview": "vite preview",
  "electron:dev": "electron .",
  "electron:build": "npm run build && electron-builder"
},

> 打包下载慢问题解决

具体地址解决文章地址:https://blog.csdn.net/weixin_46525113/article/details/132299107?fromshare=blogdetail&sharetype=blogdetail&sharerId=132299107&sharerefer=PC&sharesource=m0_47483157&sharefrom=from_link

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/

打包后文件dist目录
图片示例:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

图片示例:双击应用打开:
在这里插入图片描述

7. 优化

  • 将 vite 和 electron 的开发命令合并为一个脚本,以便在启动开发环境时同时运行 Vite 和 Electron。这可以通过使用 concurrently 包来实现

安装 concurrently 包

npm install concurrently@7 --save-dev
##好像只有指定7版本好用其他版本没试过,默认最新得报错,原因不详,不计较,7版本就行

优化 package.json 脚本

"electron:dev": "concurrently "vite" "electron ."",

完整package.json代码示例

{
  "name": "electron-vue3",
  "version": "0.0.0",
  "private": true,
  "type": "module",
  "main": "electron/main.js",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview",
    "electron:dev": "concurrently "vite" "electron ."",
    "electron:build": "npm run build && electron-builder"
  },
  "dependencies": {
    "vue": "^3.5.12"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^5.1.4",
    "concurrently": "^7.6.0",
    "electron": "^33.0.2",
    "electron-builder": "^25.1.8",
    "vite": "^5.4.10",
    "wait-on": "^6.0.1"
  },
  "description": "An Electron application with Vue 3 using Vite",
  "author": "Your Name <your.email@example.com>",
  "build": {
    "appId": "com.example.electron-vue3",
    "productName": "Electron-vue3桌面应用",
    "directories": {
      "output": "dist"
    },
    "files": [
      "dist/**/*",
      "electron/main.js"
    ],
    "win": {
      "target": "nsis",
      "requestedExecutionLevel": "highestAvailable"
    }
  }
}

以上代码完整gitee:https://gitee.com/gaiya001/Electron-Vue3-test.git

### 到目前为止一个完整得代码初始框架就搭建好啦,你可以在上面新建自己得项目啦,如果有其他问题请在评论区留言!


Electron中 main.js 文件中常用得配置

  1. 导入必要的模块
import { app, BrowserWindow, Menu, Tray, Notification, autoUpdater } from 'electron';
import path from 'path';
import { fileURLToPath } from 'url';

  1. 获取当前文件的目录路径
const __dirname = path.dirname(fileURLToPath(import.meta.url));
  1. 创建主窗口
// 创建主窗口的函数
function createWindow() {
  // 创建一个新的 BrowserWindow 实例
  const win = new BrowserWindow({
    width: 800,  // 窗口宽度
    height: 600, // 窗口高度
    webPreferences: {
      nodeIntegration: true,  // 允许 Node.js 集成
      contextIsolation: false, // 禁用上下文隔离
    },
  });

  // 加载 Vue 应用的 HTML 文件
  win.loadFile(path.join(__dirname, 'dist/index.html'));

  // 监听窗口关闭事件
  win.on('closed', () => {
    win = null;  // 清除窗口引用
  });
}

  1. 创建菜单栏
// 创建菜单栏的函数
function createMenu() {
  const template = [
    {
      label: '文件',
      submenu: [
        { label: '打开', click: () => console.log('打开文件') },
        { label: '保存', click: () => console.log('保存文件') },
        { type: 'separator' },
        { role: 'quit' }  // 退出应用
      ]
    },
    {
      label: '编辑',
      submenu: [
        { role: 'undo' },  // 撤销
        { role: 'redo' },  // 重做
        { type: 'separator' },
        { role: 'cut' },   // 剪切
        { role: 'copy' },  // 复制
        { role: 'paste' }  // 粘贴
      ]
    }
  ];

  // 构建菜单并设置为应用菜单
  const menu = Menu.buildFromTemplate(template);
  Menu.setApplicationMenu(menu);
}

  1. 创建通知
// 创建通知的函数
function createNotification() {
  const notification = new Notification({
    title: '通知标题',
    body: '这是一个通知消息'
  });

  // 显示通知
  notification.show();
}

  1. 创建托盘图标
// 创建托盘图标的函数
function createTray() {
  const tray = new Tray(path.join(__dirname, 'icon.png'));  // 托盘图标路径
  const contextMenu = Menu.buildFromTemplate([
    { label: '显示', click: () => win.show() },  // 显示窗口
    { label: '隐藏', click: () => win.hide() },  // 隐藏窗口
    { type: 'separator' },
    { label: '退出', click: () => app.quit() }  // 退出应用
  ]);

  // 设置托盘图标的提示文本和右键菜单
  tray.setToolTip('这是托盘图标');
  tray.setContextMenu(contextMenu);
}

  1. 自动更新
// 自动更新的配置
function setupAutoUpdater() {
  const feedURL = 'https://example.com/update';  // 更新服务器地址

  autoUpdater.setFeedURL(feedURL);

  autoUpdater.on('checking-for-update', () => {
    console.log('正在检查更新...');
  });

  autoUpdater.on('update-available', () => {
    console.log('发现新版本,开始下载...');
  });

  autoUpdater.on('update-not-available', () => {
    console.log('当前已是最新版本');
  });

  autoUpdater.on('update-downloaded', () => {
    console.log('更新已下载,准备安装...');
    autoUpdater.quitAndInstall();
  });

  // 检查更新
  autoUpdater.checkForUpdates();
}

  1. 应用生命周期事件
// 当 Electron 完成初始化并准备好创建浏览器窗口时
app.whenReady().then(() => {
  createWindow();  // 创建主窗口
  createMenu();    // 创建菜单栏
  createNotification();  // 创建通知
  createTray();    // 创建托盘图标
  setupAutoUpdater();  // 配置自动更新

  app.on('activate', () => {
    if (BrowserWindow.getAllWindows().length === 0) {
      createWindow();  // 如果没有打开的窗口,则重新创建
    }
  });
});

// 当所有窗口都被关闭时
app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();  // 在 macOS 以外的平台上退出应用
  }
});

主菜单 BrowserWindow 实例,窗口样式

win = new BrowserWindow({
  // 窗口的初始宽度(以像素为单位)
  width: 800,

  // 窗口的初始高度(以像素为单位)
  height: 600,

  // 窗口左上角的 x 坐标(可选)
  x: 100,

  // 窗口左上角的 y 坐标(可选)
  y: 100,

  // 窗口的最小宽度(可选)
  minWidth: 400,

  // 窗口的最小高度(可选)
  minHeight: 300,

  // 窗口的最大宽度(可选)
  maxWidth: 1200,

  // 窗口的最大高度(可选)
  maxHeight: 900,

  // 窗口是否可以调整大小(默认 `true`)
  resizable: true,

  // 窗口是否可以移动(默认 `true`)
  movable: true,

  // 窗口是否可以最小化(默认 `true`)
  minimizable: true,

  // 窗口是否可以最大化(默认 `true`)
  maximizable: true,

  // 窗口是否可以关闭(默认 `true`)
  closable: true,

  // 窗口是否可以聚焦(默认 `true`)
  focusable: true,

  // 窗口是否总是位于最顶层(默认 `false`)
  alwaysOnTop: false,

  // 窗口是否全屏显示(默认 `false`)
  fullscreen: false,

  // 窗口是否显示在任务栏中(默认 `false`)
  skipTaskbar: false,

  // 窗口是否进入 kiosk 模式(默认 `false`)
  kiosk: false,

  // 窗口的标题
  title: 'My Electron App',

  // 窗口的图标路径
  icon: path.join(__dirname, 'icon.png'),

  // 是否显示窗口框架(默认 `true`)
  frame: true,

  // 窗口是否透明(默认 `false`)
  transparent: false,

  // 窗口的背景颜色(默认 `#FFF`)
  backgroundColor: '#FFF',

  // 窗口是否有阴影(默认 `true`)
  hasShadow: true,

  // 是否使用内容区域大小作为窗口大小(默认 `false`)
  useContentSize: false,

  // 窗口创建后是否立即显示(默认 `true`)
  show: true,

  // 窗口是否居中显示(默认 `false`)
  center: true,

  // 菜单栏是否自动隐藏(默认 `false`)
  autoHideMenuBar: false,

  // 窗口是否可以全屏(默认 `true`)
  fullscreenable: true,

  // 是否使用简单的全屏模式(默认 `false`)
  simpleFullscreen: false,

  // 渲染进程的配置
  webPreferences: {
    // 是否启用 Node.js 集成(默认 `false`)。启用后,可以在渲染进程中直接使用 Node.js API。
    nodeIntegration: true,

    // 是否启用上下文隔离(默认 `true`)。启用后,Node.js 和 Chromium 的上下文被隔离,提高安全性。
    contextIsolation: false,

    // 是否启用 `remote` 模块(默认 `false`)。启用后,可以在渲染进程中使用 `remote` 模块。
    enableRemoteModule: false,

    // 预加载脚本的路径。预加载脚本在页面加载之前执行,可以用来注入全局变量或初始化一些设置。
    preload: path.join(__dirname, 'preload.js'),

    // 是否启用沙箱模式(默认 `false`)。启用后,渲染进程会被限制在沙箱环境中,提高安全性。
    sandbox: false,

    // 是否启用 Web 安全性(默认 `true`)。禁用后,可以跨域加载资源。
    webSecurity: true,

    // 是否允许加载不安全的内容(默认 `false`)
    allowRunningInsecureContent: false,

    // 是否启用 JavaScript(默认 `true`)
    javascript: true,

    // 是否启用插件(默认 `false`)
    plugins: false,

    // 是否启用实验性功能(默认 `false`)
    experimentalFeatures: false,

    // 是否启用离屏渲染(默认 `false`)
    offscreen: false,
  },
});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2236715.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Leecode】Leecode刷题之路第44天之通配符匹配

题目出处 44-通配符匹配-题目出处 题目描述 个人解法 思路&#xff1a; todo代码示例&#xff1a;&#xff08;Java&#xff09; todo复杂度分析 todo官方解法 44-通配符匹配-官方解法 前言 本题与10. 正则表达式匹配非常类似&#xff0c;但相比较而言&#xff0c;本题稍…

单元/集成测试解决方案

在项目开发的前期针对软件单元/模块功能开展单元/集成测试&#xff0c;可以尽早地发现软件Bug&#xff0c;避免将Bug带入系统测试阶段&#xff0c;有效地降低HIL测试的测试周期&#xff0c;也能有效降低开发成本。单元/集成测试旨在证明被测软件实现其单元/架构设计规范、证明被…

Linux案例:DNS服务器配置

Linux案例&#xff1a;DNS服务器配置 实验一&#xff1a;正向解析 服务端配置&#xff1a; [rootserver ~]# setenforce 0 [rootserver ~]# nmcli c modify ens160 ipv4.method manual ipv4.addresses 192.168.70.131/24 ipv4.gateway 192.168.70.2 ipv4.dns 114.114.114.11…

Linux常用的100个命令

掌握常用的Linux常用命令是作为码农的基本素养&#xff0c;无论你从事软件开发或者运维的的哪个细分领域。本文言简意赅&#xff0c;可作为指导书收藏。 Linux常用命令的分类&#xff1a; 基本文件操作权限与用户管理文件搜索与系统状态网络管理压缩与打包系统管理与维护磁盘与…

数据挖掘全景:从基础理论到经典算法的深度探索

1 绪论--1.1 数据挖掘的概念和任务 1. (单选题)目前数据分析与挖掘领域的现实情况描述不正确的是&#xff08;&#xff09; A. 信息爆炸 B. 数据爆炸 C. 信息贫瘠 D.数据收集能力远远超过人们的分析和理解能力 2. (单选题)你认为下面哪种数据对于数据挖掘算法来说最简单最…

Qt Udp的组播(多播)、广播和单播

UDP通讯的基本概念和特点‌ UDP&#xff08;User Datagram Protocol&#xff0c;用户数据报协议&#xff09;是‌TCP/IP协议族中的一种无连接协议&#xff0c;主要用于那些对实时性要求较高而可靠性要求较低的应用场景。UDP的主要特点包括&#xff1a; ‌无连接‌&#xff1a;…

CSS3中动画的使用animation

1.基本使用 2.其他属性 3.复合属性

前端实现json动画(附带示例)

前端实现json动画&#xff08;附带示例&#xff09; 使用lottie制作动画。1.json动画2.实现效果3.git仓库4.运行5.json动画天堂6.代码7. 经常使用的方法 使用lottie制作动画。 1.json动画 废话不多说&#xff0c;直接看效果图2.实现效果 3.git仓库 https://gitee.com/chaiach…

Ubuntu实现双击图标运行自己的应用软件

我们知道在Ubuntu上编写程序&#xff0c;最后编译得到的是一个可执行文件&#xff0c;大致如下 然后要运行的时候在终端里输入./hello即可 但是这样的话感觉很丑很不方便&#xff0c;下边描述一种可以类似Windows上那种双击运行的实现方式。 我们知道Ubuntu是有一些自带的程序…

【GPTs】Email Responder Pro:高效生成专业回复邮件

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AIGC | GPTs应用实例 文章目录 &#x1f4af;GPTs指令&#x1f4af;前言&#x1f4af;Email Responder Pro主要功能适用场景优点缺点 &#x1f4af;小结 &#x1f4af;GPTs指令 Email Craft is a specialized assistant for cra…

阿里云ECS服务器使用限制及不允许做的事情

阿里云ECS&#xff08;Elastic Compute Service&#xff09;是一种高性能的弹性计算服务&#xff0c;允许用户在云端创建和管理虚拟服务器。尽管ECS提供了强大的功能&#xff0c;但在使用过程中&#xff0c;阿里云有一些限制和不允许的行为。以下是一些主要的使用限制和禁止行为…

《Atomic Picnic》进不去游戏解决方法

Atomic Picnic有时候会遇到进不去游戏的情况&#xff0c;这可能是由多种原因造成的&#xff0c;玩家可以采取很多解决方法&#xff0c;比如检查电脑配置、更新系统和驱动或验证游戏文件。 Atomic Picnic进不去游戏怎么办 检查电脑配置 查看自己的电脑配置是否达到了游戏的要求…

Fastify Swagger:自动化API文档生成与展示

在现代软件开发中&#xff0c;API文档的生成和维护是一个不可或缺的环节。Fastify Swagger 是一个专为 Fastify 框架设计的插件&#xff0c;它能够自动生成符合 Swagger&#xff08;OpenAPI v2 或 v3&#xff09;规范的文档&#xff0c;从而帮助开发者轻松创建和维护API文档。本…

Nuxt3之使用lighthouse性能测试及性能优化实操

lighthouse性能测试工具 什么是 LightHouse 呢 Lighthouse 是一个开源的自动化工具&#xff0c;用于提高网页的质量。可以通过浏览器的开发者工具运行&#xff0c;也可以作为命令行工具或 Node.js 模块集成到持续集成系统中。Lighthouse 可以帮助开发者&#xff1a; 性能优化…

基于单片机的自动充电蓝牙智能台灯的设计

本设计以单片机为主要控制芯片&#xff0c;主要包括主控模块&#xff0c;显示模块&#xff0c;蓝牙模块&#xff0c;ADC转换信号模块&#xff0c;红外感应模块&#xff0c;光敏模块&#xff0c;充电模块等多功能设计。台灯分为自动模式与手动模式&#xff0c;自动模式开启时&am…

Linux操作系统:学习进程_对进程概念的深入了解

目录 前言 开篇 一、进程概念 二、进程的描述与管理 1、如何描述与管理 2、Linux中的PCB-task_struct 3、对进程组织的理解 三、进程的属性 1、系统创建进程 2、查看进程 3、进程的标识符 4、退出进程 1>ctrlc 2>kill命令杀死进程 5、用户进程的创建方式…

PointMamba: A Simple State Space Model for Point Cloud Analysis——点云论文阅读(10)

此内容是论文总结&#xff0c;重点看思路&#xff01;&#xff01; 文章概述 这篇文章提出了PointMamba&#xff0c;一种基于状态空间模型&#xff08;SSM&#xff09;的点云分析方法&#xff0c;通过引入线性复杂度算法来实现高效的全局建模。与传统基于Transformer的点云方…

【LLM】【LLaMA-Factory】:Qwen2.5-Coder-7B能力测评

1 前期准备工作 1.1 环境概述 大模型框架&#xff1a;LLaMA-Factory CG客户端镜像&#xff1a;hiyouga/LLaMA-Factory/LLaMA-Factory / v4 cpu 架构 核心数 线程数 频率 内存使用情况 操作系统 GPU&#xff1a;四张4090显卡 CUDA python 以及相关依赖包 pytorch 1.2 数据准…

OpenAI CEO阿尔特曼预测AGI可能在五年内出现 对社会的影响远小于预期

OpenAI 不断探索人工智能及其所蕴含的技术可能性的工作已经引起了相当大的反响&#xff0c;用户和科技界都对其新发布的模型及其所蕴含的先进性着迷。 在公司大力发展 AGI&#xff08;人工通用智能&#xff09;的同时&#xff0c;许多知名公司的关键员工也加入了 OpenAI&#x…

AI周报(11.3-11.9)

AI应用--商务会议旅游必备 AI同传翻译耳机 作为一个经常出差和旅游的人&#xff0c;我深知语言不通带来的困扰。每次在国外旅行&#xff0c;面对不同语言的环境&#xff0c;总是让人头疼不已。幸好&#xff0c;现在有了AI同传翻译耳机&#xff0c;出门在外也能轻松交流。 时空…