在浏览器中格式化、验证和转换TOML ↔ JSON。数据不会发送到任何服务器。
| 类型 | 示例 | 注意事项 |
|---|---|---|
| String (basic) | name = "Alice" | Supports \n, \t, \uXXXX escapes |
| String (literal) | path = 'C:\Users\Alice' | No escape processing — use for regex, paths |
| Multi-line string | desc = \"\"\" Line 1 Line 2\"\"\"`` | Opening newline trimmed |
| Integer | count = 42 hex = 0xFF bin = 0b1010 | Underscores allowed: 1_000_000 |
| Float | pi = 3.14159 sci = 5e22 inf = inf | nan also valid |
| Boolean | debug = true verbose = false | Always lowercase |
| Offset Date-Time | created = 1979-05-27T07:32:00Z | RFC 3339 / ISO 8601 |
| Local Date | date = 2024-01-15 | No time, no timezone |
| Array | tags = ["rust", "config"] | Mixed types allowed; multi-line OK |
| Inline Table | point = {x = 1, y = 2} | Must be on a single line |
| Table | [server] host = 'localhost' | Maps to nested object |
| Array of Tables | [[users]] name = 'Alice' | Creates an array of objects |
| 功能 | TOML | JSON | YAML |
|---|---|---|---|
| Comments | ✓ | ✗ | ✓ |
| Trailing commas | N/A | ✗ | N/A |
| Native dates | ✓ | ✗ | ✓ |
| Multi-line strings | ✓ | ✗ (escape \n) | ✓ |
| Implicit type coercion | ✗ | ✗ | ✓ (risky) |
| Human readability | High | Medium | High |
| Machine readability | High | High | Medium |
| Use case | Config files | APIs / data exchange | Config / automation |
TOML(Tom's Obvious, Minimal Language)是一种配置文件格式,由于语义明显而易于阅读。它明确地映射到哈希表,设计为YAML和JSON的配置文件替代方案。TOML由Rust的Cargo、Python的Poetry和许多其他工具使用。
与JSON不同,TOML支持注释、多行字符串,并具有原生日期/时间类型。与YAML不同,TOML具有显式、明确的语法 — 没有令人惊讶的隐式类型转换或缩进陷阱。TOML通常用于配置文件,而JSON用于数据交换API。
TOML表用[table.name]语法定义,映射到嵌套对象。表数组使用[[array.name]](双括号)创建对象数组。内联表使用{key = value}语法进行紧凑表示。表支持任意嵌套以实现层次配置。
TOML支持:String(基本和字面/原始)、Integer(十进制、十六进制0x、八进制0o、二进制0b)、Float(包括inf和nan)、Boolean(true/false)、Offset Date-Time(RFC 3339)、Local Date-Time、Local Date、Local Time、Array(允许混合类型)和Table/Inline Table。