Electron中文手册
  • 文档概述
  • 开发指南目录
  • 构建说明(Linux)
  • 构建说明(macOS)
  • 构建说明(Windows)
  • 构建系统概述
  • 编码规范
  • 在 macOS 中调试
  • 在 Windows 中调试
  • 在C ++代码中使用clang-format
  • 在调试器中设置符号服务器
  • 源代码目录结构
  • Chrome升级清单
  • Chromium 开发指南
  • V8 开发指南
  • 教程目录
    • 关于 Electron
    • Electron 版本说明
    • API弃用说明
    • 快速入门
    • 支持的平台
    • 桌面环境集成
    • 系统通知
    • 离屏渲染
    • 在线/离线事件检测
    • 多线程
    • REPL
    • 键盘快捷键
    • DevTools扩展
    • 使用原生模块
    • 使用 Pepper Flash 插件
    • 使用 Selenium 和 WebDriver
    • 使用 Widevine CDM 插件
    • 应用分发
    • 应用打包
    • 主进程调试
    • 使用 node-inspector 进行主进程调试
    • 使用 VSCode 进行主进程调试
    • Mac App Store应用提交指南
    • Windows App Store应用提交指南
    • 安全,本地功能和你的责任
    • Headless CI Systems 测试
  • API接口目录
    • API接口之公用接口
      • 应用语言
      • 开发概要
      • 专业术语
      • 常见问题
      • 环境变量
      • 快捷键字符串
      • 命令行
      • 客户端请求
      • 剪贴板
      • <File> H5 File文件操作
      • 无框窗口
      • <window.open> window.open打开新窗口或打开时传递消息
      • 沙盒选项
    • API接口之主进程接口
      • 整体控制
      • 全局快捷键
      • 图标创建与应用
      • 屏幕
      • 窗口
      • 菜单
      • 菜单项
      • 系统托盘
      • 网页内容
      • 从主进程到渲染进程的异步通信
      • 对话框
      • 创建和控制视图
      • 会话
      • 会话,缓存和代理等控制
      • 页面请求
      • HTTP/HTTPS请求处理
      • 协议的注册和处理
      • 使用系统默认应用程序管理文件或URL
      • 下载项管理
      • 进程控制
      • Chromium原生网络库
      • 获取系统首选项
      • 电源状态
      • 节能管理
      • 调试工具
      • 奔溃报告
      • 性能数据收集
      • 自动更新
      • TouchBar触摸条
      • TouchBar触摸条按钮
      • TouchBar触摸条拾色器
      • TouchBar触摸条分组
      • TouchBar触摸条scrubber
      • TouchBar触摸条分段控件
      • TouchBar触摸条label标签
      • TouchBar触摸条弹出框
      • TouchBar触摸条滑块
      • TouchBar触摸条间隔符
    • API接口之渲染进程接口
      • 页面渲染
      • <webview> webview标签
      • 渲染进程与主进程通信
      • 从渲染进程到主进程的异步通信
      • 子窗口
      • 捕获桌面资源
  • 结构列表
    • 蓝牙设备对象
    • 证书对象
    • 证书主体对象
    • Cookie对象
    • 崩溃报告对象
    • 桌面捕获源对象
    • 显示器对象
    • 打印机信息对象
    • 文件过滤器对象
    • 最近使用的项目
    • 常用列表项
    • CPU使用率对象即程序占用的CPU资源
    • IO值对象
    • 内存信息对象
    • 进程内存信息对象
    • 内存使用详细信息
    • Mime类型缓冲区
    • 矩形对象
    • 删除客户端证书对象
    • 删除密码对象
    • Scrubber项对象
    • 分段控制对象
    • 快捷方式对象
    • 任务对象
    • 缩略图工具栏按钮对象
    • 上传blob对象
    • 上传数据对象
    • 上传文件系统对象
    • 上传文件对象
    • 上传原始数据对象
Powered by GitBook
On this page
  • 源代码结构
  • 其他目录的结构
  • 保持Git子模块为最新

Was this helpful?

源代码目录结构

Previous在调试器中设置符号服务器NextChrome升级清单

Last updated 4 years ago

Was this helpful?

Electron 的源代码主要依据 Chromium 的拆分约定被拆成了许多部分。

为了更好地理解源代码,您可能需要了解一下

源代码结构

Electron
├── atom/ - C ++源代码.
|   ├── app/ - 系统入口代码
|   ├── browser/ - 前端包含了主窗口、UI 和其他所有与主进程有关的东西,它会告诉渲染进程如何管理页面
|   |   ├── ui/ - 不同平台上 UI 部分的实现
|   |   |   ├── cocoa/ - Cocoa特定的源代码
|   |   |   ├── win/ - Windows GUI特定的源代码
|   |   |   └── x/ - X11 特定的源代码
|   |   ├── api/ - 主进程 API 的实现
|   |   ├── net/ - 网络相关的代码
|   |   ├── mac/ - Mac特定的Objective-C源代码
|   |   └── resources/ -图标,平台相关的文件等
|   ├── renderer/ - 在渲染器进程中运行的代码
|   |   └── api/ - 渲染器进程API的实现
|   └── common/ - 同时被主进程和渲染进程用到的代码,包括了一些用来将 node 的事件循环
|      |        整合到 Chromium 的事件循环中时用到的工具函数和代码
|       └── api/ - 实现常见的API,以及Electron的内置模块的基础
├── chromium_src/ - 从Chromium复制的源代码
├── default_app/ -  当Electron未启动时显示的默认应用
├── docs/ - 文档
├── lib/ - JavaScript源代码
|   ├── browser/ -  主进程中的Javascript初始化代码
|   |   └── api/ - Javascript API实现.
|   ├── common/ - 主进程和渲染进程公用的JavaScript
|   |   └── api/ - Javascript API实现.
|   └── renderer/ - 渲染进程中的Javascript初始化代码
|       └── api/ - Javascript API实现.
├── spec/ - 自动测试
├── electron.gyp -  Electron 的构建规则
└── common.gypi -为诸如 `node` 和 `breakpad` 等其他组件准备的编译设置和构建规则

其他目录的结构

  • script - 用于诸如构建、打包、测试等开发用途的脚本

  • tools - 在 gyp 文件中用到的工具脚本,但与 script 目录不同, 该目录中的脚本不应该被用户直接调用

  • vendor - 第三方依赖项的源代码,为了防止人们将它与 Chromium 源码中的同名目录相混淆, 在这里我们不使用 third_party 作为目录名

  • node_modules - 在构建中用到的第三方 node 模块

  • out - ninja 的临时输出目录

  • dist - 由脚本 script/create-dist.py 创建的临时发布目录

  • external_binaries - 下载的不支持通过 gyp 构建的预编译第三方框架

保持Git子模块为最新

在[/vendor][vendor]目录中有一些Electron存储库的依赖项。运行 git status时你可能看到这样的提示:

$ git status
    modified:   vendor/libchromiumcontent  (new commits)
    modified:   vendor/node (new commits)

要更新这些被提供的依赖关系,请运行以下命令:

git submodule update --init --recursive

如果你发现自己经常运行这个命令,你可以在你的 ~/.gitconfig文件中为它创建一个别名:

[alias]
    su = submodule update --init --recursive

[vendor]:

Chromium 的多进程架构
https://github.com/electron/electron/tree/master/vendor