gutenbergdocs/docs/reference-guides/block-api/block-styles.md
2025-10-22 01:40:18 +08:00

5.6 KiB
Raw Permalink Blame History

样式

区块样式允许为现有区块应用替代样式。其实现原理是向区块包装器添加 className。当用户选中某个区块样式时该 className 可用于为区块提供替代样式。关于如何为区块应用样式的完整示例,请参阅使用样式和样式表

示例:

wp.blocks.registerBlockStyle( 'core/quote', {
	name: 'fancy-quote',
	label: '花式引用',
} );

以上示例为 core/quote 区块注册了名为 fancy-quote 的区块样式。当用户从样式选择器中选中此区块样式时,区块包装器将添加 is-style-fancy-quote 的 className。

通过设置 isDefault: true,可将注册的区块样式标记为未提供自定义类名时的默认激活样式。这也意味着标记为默认的样式不会在 HTML 输出中添加自定义类名。

如需移除区块样式,请使用 wp.blocks.unregisterBlockStyle()

示例:

wp.blocks.unregisterBlockStyle( 'core/quote', 'large' );

以上代码将从 core/quote 区块中移除名为 large 的区块样式。

重要提示: 在取消注册区块样式时,可能存在竞态条件——注册样式和取消注册样式的代码执行顺序不确定。为确保取消注册代码最后执行,需将注册样式的组件(本例中为 wp-edit-post)指定为依赖项。此外,使用 wp.domReady() 可确保取消注册代码在 DOM 加载完成后执行。

通过以下 PHP 代码加载你的 JavaScript

function myguten_enqueue() {
	wp_enqueue_script(
		'myguten-script',
		plugins_url( 'myguten.js', __FILE__ ),
		array( 'wp-blocks', 'wp-dom-ready', 'wp-edit-post' ),
		filemtime( plugin_dir_path( __FILE__ ) . '/myguten.js' )
	);
}
add_action( 'enqueue_block_editor_assets', 'myguten_enqueue' );

myguten.js 中的 JavaScript 代码:

wp.domReady( function () {
	wp.blocks.unregisterBlockStyle( 'core/quote', 'large' );
} );

服务端注册辅助函数

虽然提供的示例能完全控制区块样式,但需要编写大量代码。

为简化注册和取消注册区块样式的流程,还提供了两个服务端函数:register_block_styleunregister_block_style

register_block_style

register_block_style 函数的第一个参数接收区块名称,第二个参数接收描述样式属性的数组。

样式数组的属性必须包含 namelabel

  • name:用于计算 CSS 类的样式标识符
  • label:用户可读的样式标签

除了这两个必需属性外,样式属性数组还应包含 inline_stylestyle_handlestyle_data 属性之一:

  • inline_style:包含注册样式所需 CSS 类的内联 CSS 代码
  • style_handle:包含已注册样式句柄,该样式将在需要区块样式的地方被加载
  • style_data:包含 theme.json 风格的样式属性数组(自 WordPress 6.6 起可用)

还可以将 is_default 属性设置为 true,将某个区块样式标记为默认样式。

以下代码示例为引用区块注册名为“蓝色引用”的样式,并提供内联样式使采用“蓝色引用”样式的引用区块显示为蓝色:

register_block_style(
    'core/quote',
    array(
        'name'         => 'blue-quote',
        'label'        => __( '蓝色引用', 'textdomain' ),
        'inline_style' => '.wp-block-quote.is-style-blue-quote { color: blue; }',
    )
);

如果已注册包含区块样式 CSS 的样式表,只需传递样式表句柄,register_block_style 函数将确保其被加载:

wp_register_style( 'myguten-style', get_template_directory_uri() . '/custom-style.css' );

// ...

register_block_style(
    'core/quote',
    array(
        'name'         => 'fancy-quote',
        'label'        => __( '花式引用', 'textdomain' ),
        'style_handle' => 'myguten-style',
    )
);

另一种方式是使用 style_data 属性(如下例),为图片区块添加带橙色边框和微圆角的样式:

register_block_style(
       array( 'core/image' ),
       array(
           'name'         => 'orange-border',
           'label'        => __( '橙色边框', 'pauli' ),
           'style_data'=> array(
                           'border' => array(
                           'color' => '#f5bc42',
                           'style' => 'solid',
                           'width' => '4px',
                           'radius' => '15px'
            )
        )
    )
);

使用 style_data 属性允许用户通过编辑器 > 样式中的全局样式界面进行修改。该属性自 WordPress 6.6 版本开始提供。

更多信息请参阅 WordPress 6.6 开发说明:区块样式章节。 另见 WordPress 开发者博客:在 WordPress 6.6 中使用区块样式变体为区块区域、嵌套元素等设置样式

unregister_block_style

unregister_block_style 用于取消注册之前通过 register_block_style 在服务端注册的区块样式。

函数的第一个参数是区块的注册名称,第二个参数是样式名称。

以下代码示例从引用区块中取消注册名为 'fancy-quote' 的样式:

unregister_block_style( 'core/quote', 'fancy-quote' );

重要说明: unregister_block_style 函数仅取消注册通过 register_block_style 在服务端注册的样式,不会取消注册通过客户端代码注册的样式。