wp_apply_spacing_support

函数
wp_apply_spacing_support ( $block_type, $block_attributes )
Access
Private
参数
  • (WP_Block_Type) $block_type Block Type.
    Required:
  • (array) $block_attributes Block attributes.
    Required:
返回值
  • (array) Block spacing CSS classes and inline styles.
定义位置
相关方法
wp_apply_alignment_supportwp_apply_colors_supportwp_apply_typography_supportwp_register_spacing_supportwp_apply_dimensions_support
引入
5.8.0
弃用
-

wp_apply_spacing_support: 这是一个用于对一个HTML元素应用间距支持的函数。它接收一个HTML字符串和一个间距参数作为输入,并返回应用了间距的修改后的HTML字符串。

在传入的属性数组中添加用于块间距的CSS类。

这将被应用到前端的区块标记中。

function wp_apply_spacing_support( $block_type, $block_attributes ) {
	if ( wp_should_skip_block_supports_serialization( $block_type, 'spacing' ) ) {
		return array();
	}

	$attributes          = array();
	$has_padding_support = block_has_support( $block_type, array( 'spacing', 'padding' ), false );
	$has_margin_support  = block_has_support( $block_type, array( 'spacing', 'margin' ), false );
	$block_styles        = isset( $block_attributes['style'] ) ? $block_attributes['style'] : null;

	if ( ! $block_styles ) {
		return $attributes;
	}

	$skip_padding                    = wp_should_skip_block_supports_serialization( $block_type, 'spacing', 'padding' );
	$skip_margin                     = wp_should_skip_block_supports_serialization( $block_type, 'spacing', 'margin' );
	$spacing_block_styles            = array();
	$spacing_block_styles['padding'] = $has_padding_support && ! $skip_padding ? _wp_array_get( $block_styles, array( 'spacing', 'padding' ), null ) : null;
	$spacing_block_styles['margin']  = $has_margin_support && ! $skip_margin ? _wp_array_get( $block_styles, array( 'spacing', 'margin' ), null ) : null;
	$styles                          = wp_style_engine_get_styles( array( 'spacing' => $spacing_block_styles ) );

	if ( ! empty( $styles['css'] ) ) {
		$attributes['style'] = $styles['css'];
	}

	return $attributes;
}

常见问题

FAQs
查看更多 >