Electron案例解析-获取 Chrome、Node.js和Electron版本号的应用案例

实现效果

目录结构

index.html

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8" />

<!-- 内容安全策略-->
    <meta
            http-equiv="Content-Security-Policy"
            content="default-src 'self'; script-src 'self'"
    />

    <meta
            http-equiv="X-Content-Security-Policy"
            content="default-src 'self'; script-src 'self'"
    />
    <!--窗口标题-->
    <title>你好,Electron!</title>
</head>
<body>

<h1>你好,Electron!</h1>
<p>👋</p>
<p id="info"></p>
</body>
<!-- 加载渲染进程的 renderer.js 文件 -->
<script src="./renderer.js"></script>
</html>

main.js

javascript 复制代码
//引入electron模块 app, BrowserWindow
const {app, BrowserWindow} = require('electron/main') //引入electron模块, app
const path = require('node:path') //引入path模块
//创建窗口
const createWindow = () => {
  const win = new BrowserWindow({
    //设置窗口大小 宽度800 高度600
    width: 800,
    height: 600,
    webPreferences: {  //网页设置
      preload: path.join(__dirname, 'preload.js') //设置预加载脚本
    }
  })
//加载index.html
  win.loadFile('index.html')
}

//当Electron完成初始化并且准备创建窗口时调用createWindow()
app.whenReady().then(() => {
  //在应用准备就绪时调用函数
  createWindow()

  //如果没有窗口打开则打开一个窗口 (macOS) 这个是必须处理的兼容性问题
  app.on('activate', () => {
    if (BrowserWindow.getAllWindows().length === 0) {
      createWindow()
    }
  })
})

/**
 * 关闭所有窗口时退出应用 (Windows & Linux) 这个是必须处理的兼容性问题。
 * 这段代码是用于Electron框架中的事件监听,具体是监听window-all-closed事件。这个事件会在所有窗口都被关闭时触发。
 * 代码中的逻辑是,如果当前操作系统平台不是macOS('darwin'),则在所有窗口关闭后退出应用程序。
 * */
app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') app.quit()
})

preload.js

javascript 复制代码
/**
 * 预加载脚本在加载"index.html"之前运行在渲染器中。
 * 它可以访问Web API以及Electronic的渲染器处理模块和一些多边填充Node.Js功能。
 * https://www.electronjs.org/docs/latest/tutorial/sandbox
 */
// 引入electron模块,contextBridge用于暴露接口到主进程
const { contextBridge } = require('electron/renderer')

// 在主进程暴露接口,接口名为versions,返回当前Node.js、Chrome和Electron的版本号
contextBridge.exposeInMainWorld('versions', {
    node: () => process.versions.node,          // 返回Node.js版本号
    chrome: () => process.versions.chrome,      // 返回Chrome版本号
    electron: () => process.versions.electron   // 返回Electron版本号
})

renderer.js

javascript 复制代码
//这个文件是renderer进程的入口文件,负责渲染页面的显示。

//获取info节点
const information = document.getElementById('info')
//改变info节点的文本内容,显示当前应用的版本信息,包括Chrome、Node.js和Electron的版本号,并显示在info节点中。
information.innerText = `这个应用使用了 Chrome (v${window.versions.chrome()}), Node.js (v${window.versions.node()}), and Electron (v${window.versions.electron()})`

styles.css

css 复制代码
//这里没有代码

获取 Chrome、Node.js和Electron版本号的应用案例的案例效果

相关推荐
Java开发追求者1 小时前
npm镜像源证书过期的问题解决
前端·npm·node.js·npm镜像源证书过期的问题解决
骨子里的偏爱5 小时前
uniapp与webview直接进行传值
前端·chrome·uni-app
Zhen (Evan) Wang10 小时前
vs code: pnpm : 无法加载文件 C:\Program Files\nodejs\pnpm.ps1,因为在此系统上禁止运行脚本
vue.js·vscode·npm·node.js·angular
营赢盈英12 小时前
How to see if openAI (node js) createModeration response “flagged“ is true
javascript·ai·node.js·openai·api
GISer_Jing12 小时前
切换淘宝最新镜像源npm
前端·npm·node.js
乐hh12 小时前
nvm无法下载npm的问题
前端·npm·node.js·vue·nvm
埋头编程~13 小时前
【Linux】常用指令(中)(附带基础指令的详细讲解、Linux的一些附加知识)
linux·运维·服务器·chrome·学习
浏览器爱好者20 小时前
如何在Chrome中使用HTML构建交互式网页
前端·chrome·html
gs8014020 小时前
安装node 报错需要:glibc >= 2.28
linux·服务器·前端·node.js
生活真难1 天前
node解析dxf文件
javascript·arcgis·node.js