以下是 Electron 项目的编码规范,您可以运行
npm run lint
来显示cpplint
和eslint
检测到的任何规范问题
对于C ++和Python,我们遵循Chromium的编码风格. 您可以使用clang-format自动格式化C ++代码.也可以使用 script/cpplint.py
来检验文件是否符合要求.
我们目前使用的 Python 版本是 Python 2.7.
C++ 代码中用到了许多 Chromium 中的接口和数据类型,因此建议你能熟悉它们.Chromium 中的重要接口和数据结构就是一篇不错的入门文档,里面提到了一些特殊类型、域内类型(退出作用域时自动释放内存)、日志机制,等等.
-
文件名使用
-
而不是_
来连接单词,比如file-name.js
而不是file_name.js
,这是沿用 github/atom 模块的命名方式(module-name
).这条规则仅适用于.js
文件. -
在适当的地方使用较新的ES6/ES2015语法
const
- 规定的或其他常量let
- 用于定义变量- Arrow functions- 而不是
function(){}
- Template literal - 而不是字符串连接使用
+
Electron API使用与Node.js相同的大小写方案:
- 当模块是一个类似
BrowserWindow
的类,用CamelCase
. - 当模块是一组类似
globalShortcut
的API,用mixCase
. - 当API是一个复杂的对象属性,例如
win.webContents
, 用mixedCase
. - 非模块API则使用自然标题,如
<webview> Tag
或Process Object
.
当新建一个 API 时,我们倾向于使用 getters 和 setters 而不是 jQuery 单函数的命名方式,比如 .getText()
和 .setText(text)
,而不是 .text([text])
.这里有关于该规则的讨论记录.