_get_block_template_file

函式
_get_block_template_file ( $template_type, $slug )
Access
Private
引數
  • (string) $template_type 'wp_template' or 'wp_template_part'.
    Required:
  • (string) $slug Template slug.
    Required:
返回值
  • (array|null) Template.
定義位置
相關方法
_get_block_templates_filesget_block_templateget_block_templates_get_block_templates_pathsget_the_block_template_html
引入
5.9.0
棄用
-

_get_block_template_file: 這是一個用來獲取特定塊模板檔案路徑的函式。它接收一個模板名稱作為引數,並返回塊模板檔案的路徑。

從主題中為一個給定的slug檢索模板檔案。

function _get_block_template_file( $template_type, $slug ) {
	if ( 'wp_template' !== $template_type && 'wp_template_part' !== $template_type ) {
		return null;
	}

	$themes = array(
		get_stylesheet() => get_stylesheet_directory(),
		get_template()   => get_template_directory(),
	);
	foreach ( $themes as $theme_slug => $theme_dir ) {
		$template_base_paths = get_block_theme_folders( $theme_slug );
		$file_path           = $theme_dir . '/' . $template_base_paths[ $template_type ] . '/' . $slug . '.html';
		if ( file_exists( $file_path ) ) {
			$new_template_item = array(
				'slug'  => $slug,
				'path'  => $file_path,
				'theme' => $theme_slug,
				'type'  => $template_type,
			);

			if ( 'wp_template_part' === $template_type ) {
				return _add_block_template_part_area_info( $new_template_item );
			}

			if ( 'wp_template' === $template_type ) {
				return _add_block_template_info( $new_template_item );
			}

			return $new_template_item;
		}
	}

	return null;
}

常見問題

FAQs
檢視更多 >