Gutenberg 区块编辑器文档

title: "迁移 Theme.json 至新版本" post_status: publish comment_status: open taxonomy: category: - gutenberg-docs post_tag: - Theme Json Reference - Reference Guides - Repos


迁移 Theme.json 至新版本

本指南记录了不同 theme.json 版本间的变更及升级方法。旧版本将继续获得支持,但建议进行升级,因为新功能开发将集中于新版本。

从 v1 迁移到 v2

升级到 v2 版本可启用一些新功能,并调整部分旧功能的命名,使其更加统一。

如何从 v1 迁移到 v2:

  1. version 更新为 2
  2. 如果你正在使用已更新的属性,请重命名它们(见下文)。

请参考版本发布的开发说明以及 v1 和 v2 版本各自的参考文档

Renamed properties

v1 v2
settings.border.customRadius settings.border.radius
settings.spacing.customMargin settings.spacing.margin
settings.spacing.customPadding settings.spacing.padding
settings.typography.customLineHeight settings.typography.lineHeight

新增属性

新增顶级属性:customTemplatestemplateParts

设置部分新增:

样式部分新增:

属性值变更

核心提供的默认字体大小 (settings.typography.fontSizes) 已更新。常规和超大尺寸(对应 normalhuge 标识)已从列表中移除,并添加了特大尺寸(对应 x-large 标识)。当 UI 控件显示核心提供的默认值时,将不再包含常规和超大尺寸。不过,它们的 CSS 类和 CSS 自定义属性仍会入队,以确保使用它们的现有内容仍能正常工作。

从 v2 迁移到 v3

升级到 v3 版本调整了预设默认值,使其彼此之间更加一致。

如何从 v2 迁移到 v3:

  1. version 更新为 3
  2. 配置已更改的默认值(见下文)。

默认设置变更

settings.typography.defaultFontSizes

在 theme.json v2 中,默认字体大小仅在未定义主题尺寸时显示。若主题提供的字体大小使用与默认值相同的标识符,则会始终覆盖默认值。

默认的 fontSizes 标识符包括:smallmediumlargex-largexx-large

新的 defaultFontSizes 选项可控制是否显示默认字体大小,并防止这些默认值被覆盖。

切换到 v3 时,此选项默认值为 true。这是为了与其他 default* 选项(如 settings.color.defaultPalette)保持一致,但与 v2 的行为不同。

要在 v3 的 theme.json 中保持类似 v2 的行为: * 若未定义任何 fontSizes,可省略 defaultFontSizes 或将其设为 true。 * 若已定义部分 fontSizes,请将 defaultFontSizes 设为 false

settings.spacing.defaultSpacingSizes

在 theme.json v2 中,有两个设置可用于定义主题级别的间距尺寸:settings.spacing.spacingSizessettings.spacing.spacingScale。同时设置 spacingSizes spacingScale 将仅使用 spacingSizes 中的值。设置其中任何一个都将始终替换 WordPress 提供的整套默认间距尺寸。

WordPress 提供的默认 spacingSizes 标识符为:20304050607080

新的 defaultSpacingSizes 选项提供了控制是否显示默认间距尺寸以及防止这些默认值被覆盖的能力。

切换到 v3 时,defaultSpacingSizes 默认为 true。这是为了与其他 default* 选项(如 settings.color.defaultPalette)的工作方式保持一致,但与 v2 中的行为不同。

此外,在 v3 中,可以同时设置 spacingSizesspacingScale。在 spacingSizes 中定义的、标识符与 spacingSizes 生成的预设匹配的预设将覆盖生成的预设。

要在 v3 的 theme.json 中保持与 v2 类似的行为: * 如果您没有定义任何 spacingSizes 预设或 spacingScale 配置,可以省略 defaultSpacingSizes 或将其设置为 true。 * 如果您曾通过将 spacingScale 设置为 { "steps": 0 } 来禁用默认间距尺寸,请移除 spacingScale 配置并将 defaultSpacingSizes 设置为 false。 * 如果您仅为预设定义了 spacingScalespacingSizes 中的一个,请将 defaultSpacingSizes 设置为 false。 * 如果您同时定义了 spacingScalespacingSizes,请移除 spacingSizes 配置 defaultSpacingSizes 设置为 false