前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >客户端开发(Electron)主题切换

客户端开发(Electron)主题切换

作者头像
前端小鑫同学
发布2022-12-26 09:51:08
1.3K0
发布2022-12-26 09:51:08
举报

Dear,大家好,我是“前端小鑫同学”,😇长期从事前端开发,安卓开发,热衷技术,在编程路上越走越远~

Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 嵌入 Chromium 和 Node.js 到 二进制的 Electron 允许您保持一个 JavaScript 代码代码库并创建 在Windows上运行的跨平台应用 macOS和Linux——不需要本地开发 经验。

前情概要:

上一篇通过快速入门我们搭建了最基础的HelloWorld模型,我们接下来就要在这个最基础的项目中来做后续的基础性功能实战。 ​

本篇说明:

主题切换在安卓、IOS、PC网站的应用的特别的广泛,在第一次接触flutter的时候第一次做状态切换的案例同样也是主题切换,巧了,学习electron的第一个案例也是,具体用到了哪些知识呢?我们先演示后总结。 ​

准备本篇的首页:

  1. 支持显示当前的主题来源:跟随系统/手动切换;
  2. 提供两个按钮来触发切换事件;
  3. 通过renderer脚本来进行渲染。
代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>黑暗主题</title>
    <meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline';" />
    <link rel="stylesheet" type="text/css" href="./styles.css">
</head>

<body>
    <h1>黑暗主题</h1>
    <p>当前主题来源:<strong id="theme-source">System</strong></p>

    <button id="toggle-dark-mode">开启黑暗主题模式</button>
    <button id="reset-to-system">重置为系统主题模式</button>

    <script src="renderer.js"></script>
</body>

</html>
代码语言:javascript
复制
@media (prefers-color-scheme: dark) {
  body {
    background: #333;
    color: white;
  }
}
@media (prefers-color-scheme: light) {
  body {
    background: #ddd;
    color: black;
  }
}

预加载注入函数脚本:

  • 在主窗口暴露名为darkMode对象并分配两个函数,分别将信息传到主进程中
代码语言:javascript
复制
const { contextBridge, ipcRenderer } = require("electron");
contextBridge.exposeInMainWorld("darkMode", {
toggle: () => ipcRenderer.invoke("dark-mode:toggle"),
system: () => ipcRenderer.invoke("dark-mode:system"),
});

在renderer.js脚本实际操作DOM事件:

  • 通过监听按钮的事件来触发预加载脚本扩展的桥接函数
代码语言:javascript
复制
document
  .getElementById("toggle-dark-mode")
  .addEventListener("click", async () => {
    const isDarkMode = await window.darkMode.toggle();
    document.getElementById("theme-source").innerHTML = isDarkMode
      ? "Dark"
      : "Light";
  });

document
  .getElementById("reset-to-system")
  .addEventListener("click", async () => {
    await window.darkMode.system();
    document.getElementById("theme-source").innerHTML = "System";
  });
复制代码

窗口创建后在主进程监听渲染进程的执行:

  • 我们需要在出进程中监听对应的事件来最终切换主题的来源
代码语言:javascript
复制
// 主进程相应HTML上的点击事件
  ipcMain.handle("dark-mode:toggle", () => {
    if (nativeTheme.shouldUseDarkColors) {
      nativeTheme.themeSource = "light";
    } else {
      nativeTheme.themeSource = "dark";
    }
    return nativeTheme.shouldUseDarkColors;
  });

  ipcMain.handle("dark-mode:system", () => {
    nativeTheme.themeSource = "system";
  });
复制代码

总结:

本篇我们初步学到了一下4小点:

  1. 脚本中如何注入桥接函数;
  2. 渲染进程发送事件;
  3. 主进行监听事件;
  4. 主题来源的切换。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-01-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前情概要:
  • 本篇说明:
  • 准备本篇的首页:
  • 预加载注入函数脚本:
  • 在renderer.js脚本实际操作DOM事件:
  • 窗口创建后在主进程监听渲染进程的执行:
  • 总结:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档